问题 J: Red is good
时间限制: 1 Sec 内存限制: 64 MB题目描述
桌面上有R张红牌和B张黑牌,随机打乱顺序后放在桌面上,开始一张一张地翻牌,翻到红牌得到1美元,黑牌则付出1美元。可以随时停止翻牌,在最优策略下平均能得到多少钱。
输入
一行输入两个数R,B,其值在0到5000之间
输出
在最优策略下平均能得到多少钱。
样例输入
5 1
样例输出
4.166666
提示
输出答案时,小数点后第六位后的全部去掉,不要四舍五入.
f[i][j] 还剩i张红 j张黑可得最大价值
i==0 0
j==0 i
else f[i][j]=max(0,i/(i+j)*(1+f[i-1][j])+j/(i+j)*(-1+f[i][j-1]));
#include<iostream>
#include<cmath>
#include<cstring>
#include<cstdio>
#include<queue>
#include<map>
#include<cstdlib>
#include<algorithm>
#define V 5090
#define LL long long
using namespace std;
double f[2][V];
int n,m;
inline int haha()
{//freopen("in.txt","r",stdin);cin>>n>>m;double x,y;int num=0;for(int i=0;i<=n;i++){num^=1;for(int j=0;j<=m;j++){if(i==0){f[num][j]=0;continue; }if(j==0){f[num][j]=i;continue;}x=i;y=j;f[num][j]=max(0.0,x/(x+y)*(1+f[num^1][j])+y/(x+y)*(-1+f[num][j-1]));}}double xx=0.0000005;f[num][m]-=xx;printf("%.6lf",f[num][m]);//cout<<f[n][m];return 0;
}
int gg=haha();
int main()
{;}