CodeForces

http://codeforces.com/problemset/problem/148/D

题目大意:

  原来袋子里有w只白鼠和b只黑鼠

  龙和王妃轮流从袋子里抓老鼠。谁先抓到白色老鼠谁就赢。

  王妃每次抓一只老鼠,龙每次抓完一只老鼠之后会有一只老鼠跑出来。

  每次抓老鼠和跑出来的老鼠都是随机的。

  如果两个人都没有抓到白色老鼠则龙赢。王妃先抓。

  问王妃赢的概率。

 (0 ≤ w, b ≤ 1000).

题解:

  

  其中第一行表示为王妃拿到的白色老鼠,自然是直接退出了

  第二行表示为王妃拿到了黑色老鼠,但是因为不能让龙赢,所以龙必须要抓到黑色老鼠

  那么就应该讨论龙抓完后跑出来的是黑色老鼠还是白色老鼠

  即为对应的2、3两行

 1 #include <cstdio>
 2 #include <cstring>
 3 #include <algorithm>
 4 using namespace std;
 5 typedef long long ll;
 6 inline void read(int &x){
 7     x=0;char ch;bool flag = false;
 8     while(ch=getchar(),ch<'!');if(ch == '-') ch=getchar(),flag = true;
 9     while(x=10*x+ch-'0',ch=getchar(),ch>'!');if(flag) x=-x;
10 }
11 inline int cat_max(const int &a,const int &b){return a>b ? a:b;}
12 inline int cat_min(const int &a,const int &b){return a<b ? a:b;}
13 const int maxn = 1024;
14 double f[maxn][maxn];
15 int main(){
16     int n,m;read(n);read(m);
17     for(int i=0;i<=n;++i) f[i][0] = 1.0;
18     for(int i=0;i<=m;++i) f[0][i] = 0.0;
19     for(int i=1;i<=n;++i){
20         for(int j=1;j<=m;++j){
21             f[i][j] = (double)i/(i+j);
22             if(j-3>=0) f[i][j] += (double)j/(i+j)*(j-1)/(i+j-1)*(j-2)/(i+j-2)*f[i][j-3];
23             if(j-2>=0) f[i][j] += (double)j/(i+j)*(j-1)/(i+j-1)*i/(i+j-2)*f[i-1][j-2];
24         }
25     }printf("%.9lf
",f[n][m]);
26     getchar();getchar();
27     return 0;
28 }
29   
原文地址:https://www.cnblogs.com/Skyminer/p/6256088.html