【HDU】3076 ssworld VS DDD 概率DP
发布时间:2020-12-13 22:46:14 所属栏目:百科 来源:网络整理
导读:传送门:【HDU】3076 ssworld VS DDD 题目分析:简单的概率DP。。不过要搞清楚转移边界。。。我就因为边界问题一直wa。。 PS:题目数据给的血量是反的!数据错了 代码如下: #include cmath#include cstdio#include cstring#include algorithmusing namespac
传送门:【HDU】3076 ssworld VS DDD
题目分析:简单的概率DP。。不过要搞清楚转移边界。。。我就因为边界问题一直wa。。 PS:题目数据给的血量是反的!数据错了
代码如下:
#include <cmath> #include <cstdio> #include <cstring> #include <algorithm> using namespace std ; #define REP( i,a,b ) for ( int i = a ; i < b ; ++ i ) #define REV( i,b ) for ( int i = a ; i >= b ; -- i ) #define FOR( i,b ) for ( int i = a ; i <= b ; ++ i ) #define CLR( a,x ) memset ( a,x,sizeof a ) #define CPY( a,x ) memcpy ( a,sizeof a ) const int MAXN = 2005 ; const double eps = 1e-8 ; int n,m ; double dp[MAXN][MAXN] ; double player1[6],player2[6] ; double win,tie,lose ; void solve () { tie = win = lose = 0 ; REP ( i,6 ) scanf ( "%lf",player1 + i ) ; REP ( i,player2 + i ) ; REP ( i,6 ) REP ( j,6 ) { double tmp = player1[i] * player2[j] ; if ( i > j ) win += tmp ; else if ( i == j ) tie += tmp ; else lose += tmp ; } FOR ( i,n + 1 ) dp[i][m + 1] = 0 ; FOR ( i,m + 1 ) dp[n + 1][i] = 0 ; dp[n][m] = 1.0 ; REV ( i,n,1 ) REV ( j,m,0 ) { if ( i == n && j == m ) continue ; dp[i][j] = win * dp[i][j + 1] ; if ( j ) dp[i][j] += lose * dp[i + 1][j]; dp[i][j] /= ( 1 - tie ) ; } double ans = 0 ; FOR ( i,1,n ) ans += dp[i][0] ; printf ( "%.6fn",ans ) ; } int main () { while ( ~scanf ( "%d%d",&m,&n ) ) solve () ; return 0 ; } (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |