codeforces 148D
题意:
袋
中
有
w
只
白
鼠
和
b
只
黑
鼠
,
王
妃
和
龙
轮
流
从
袋
中
抓
取
,
谁
先
抓
到
白
鼠
谁
胜
。
袋中有w只白鼠和b只黑鼠,王妃和龙轮流从袋中抓取,谁先抓到白鼠谁胜。
袋中有w只白鼠和b只黑鼠,王妃和龙轮流从袋中抓取,谁先抓到白鼠谁胜。
王
妃
先
抓
,
然
后
龙
抓
,
龙
抓
完
后
会
随
机
逃
走
一
直
老
鼠
。
王妃先抓,然后龙抓,龙抓完后会随机逃走一直老鼠。
王妃先抓,然后龙抓,龙抓完后会随机逃走一直老鼠。
若
袋
中
老
鼠
抓
完
但
王
妃
和
龙
都
没
抓
到
白
鼠
,
则
龙
获
胜
。
若袋中老鼠抓完但王妃和龙都没抓到白鼠,则龙获胜。
若袋中老鼠抓完但王妃和龙都没抓到白鼠,则龙获胜。
问
王
妃
获
胜
的
概
率
。
问王妃获胜的概率。
问王妃获胜的概率。
题解:
d
p
[
i
]
[
j
]
表
示
袋
中
还
剩
i
只
白
鼠
和
j
只
黑
鼠
时
王
妃
获
胜
的
概
率
。
dp[i][j]表示袋中还剩i只白鼠和j只黑鼠时王妃获胜的概率。
dp[i][j]表示袋中还剩i只白鼠和j只黑鼠时王妃获胜的概率。
王
妃
获
胜
的
必
要
条
件
是
龙
始
终
抓
到
黑
鼠
。
王妃获胜的必要条件是龙始终抓到黑鼠。
王妃获胜的必要条件是龙始终抓到黑鼠。
- 王 妃 抓 到 白 鼠 , d p [ i ] [ j ] = i ∗ i i + j 王妃抓到白鼠,dp[i][j] = i*\frac i{i+j} 王妃抓到白鼠,dp[i][j]=i∗i+ji
- 王 妃 抓 到 黑 鼠 , 龙 抓 完 跑 掉 黑 鼠 , d p [ i ] [ j ] + = d p [ i ] [ j − 3 ] ∗ j i + j ∗ j − 1 i + j − 1 ∗ j − 2 i + j − 2 王妃抓到黑鼠,龙抓完跑掉黑鼠,dp[i][j] += dp[i][j-3]*\frac j{i+j}*\frac {j-1}{i+j-1}*\frac {j-2}{i+j-2} 王妃抓到黑鼠,龙抓完跑掉黑鼠,dp[i][j]+=dp[i][j−3]∗i+jj∗i+j−1j−1∗i+j−2j−2
- 王 妃 抓 到 黑 鼠 , 龙 抓 完 跑 掉 白 鼠 , d p [ i ] [ j ] + = d p [ i − 1 ] [ j − 2 ] ∗ j i + j ∗ j − 1 i + j − 1 ∗ i i + j − 2 王妃抓到黑鼠,龙抓完跑掉白鼠,dp[i][j] += dp[i-1][j-2]*\frac j{i+j}*\frac {j-1}{i+j-1}*\frac i{i+j-2} 王妃抓到黑鼠,龙抓完跑掉白鼠,dp[i][j]+=dp[i−1][j−2]∗i+jj∗i+j−1j−1∗i+j−2i
#include <bits\stdc++.h>
using namespace std;
const int N = 1001;
double dp[N][N];
int main() {
int w, b;
cin >> w >> b;
for(int i = 1 ; i <= w ; i++){
dp[i][0] = 1;
}
for(int i = 1 ; i <= w ; i++){
for(int j = 1 ; j <= b ; j++){
dp[i][j] = i*1.0/(i+j);
if(j >= 2){
dp[i][j] += j*1.0/(i+j)*(j-1)*1.0/(i+j-1)*i*1.0/(i+j-2)*dp[i-1][j-2];
}
if( j >= 3){
dp[i][j] += j*1.0/(i+j)*(j-1)*1.0/(i+j-1)*(j-2)*1.0/(i+j-2)*dp[i][j-3];
}
}
}
cout << setiosflags(ios::fixed) << setprecision(9) << dp[w][b] << endl;
return 0;
}