BZOJ1419Red is good——概率DP

题目描述

桌面上有R张红牌和B张黑牌,随机打乱顺序后放在桌面上,开始一张一张地翻牌,翻到红牌得到1美元,黑牌则付
出1美元。可以随时停止翻牌,在最优策略下平均能得到多少钱。

输入

一行输入两个数R,B,其值在0到5000之间

输出

在最优策略下平均能得到多少钱。

样例输入

5 1

样例输出

4.166666

提示

输出答案时,小数点后第六位后的全部去掉,不要四舍五入.

 

算是概率dp入门题了,f[i][j]表示剩下i张红牌j张黑牌的期望收益,f[i][j]=max(0,i/(i+j)*(1+f[i-1][j])+j/(i+j)*(-1+f[i][j-1])),转移很好理解,如果期望收益小于0了,那么剩下的就都不选了。注意内存较小要滚动数组且小数不要四舍五入。

#include<set>
#include<map>
#include<cmath>
#include<stack>
#include<queue>
#include<cstdio>
#include<vector>
#include<cstring>
#include<iostream>
#include<algorithm>
#define ll long long 
using namespace std;
int n,m;
double f[3][5010];
int main()
{
    scanf("%d%d",&n,&m);
    int now=0;
    for(int i=1;i<=n;i++,now^=1)
    {
        f[now][0]=i;
        for(int j=1;j<=m;j++)
        {
            f[now][j]=max(0*1.0,1.0*i/(i+j)*(1+f[now^1][j])+1.0*j/(i+j)*(-1+f[now][j-1]));
        }
    }
    ll x=1000000*f[now^1][m];
    printf("%.6lf",1.0*x/1000000);
}
posted @ 2018-09-28 19:35  The_Virtuoso  阅读(246)  评论(0编辑  收藏  举报