codeforces 148D 概率DP

codeforces 148D


题意:

袋 中 有 w 只 白 鼠 和 b 只 黑 鼠 , 王 妃 和 龙 轮 流 从 袋 中 抓 取 , 谁 先 抓 到 白 鼠 谁 胜 。 袋中有w只白鼠和b只黑鼠,王妃和龙轮流从袋中抓取,谁先抓到白鼠谁胜。 wb
王 妃 先 抓 , 然 后 龙 抓 , 龙 抓 完 后 会 随 机 逃 走 一 直 老 鼠 。 王妃先抓,然后龙抓,龙抓完后会随机逃走一直老鼠。
若 袋 中 老 鼠 抓 完 但 王 妃 和 龙 都 没 抓 到 白 鼠 , 则 龙 获 胜 。 若袋中老鼠抓完但王妃和龙都没抓到白鼠,则龙获胜。
问 王 妃 获 胜 的 概 率 。 问王妃获胜的概率。


题解:

d p [ i ] [ j ] 表 示 袋 中 还 剩 i 只 白 鼠 和 j 只 黑 鼠 时 王 妃 获 胜 的 概 率 。 dp[i][j]表示袋中还剩i只白鼠和j只黑鼠时王妃获胜的概率。 dp[i][j]ij
王 妃 获 胜 的 必 要 条 件 是 龙 始 终 抓 到 黑 鼠 。 王妃获胜的必要条件是龙始终抓到黑鼠。

  • 王 妃 抓 到 白 鼠 , d p [ i ] [ j ] = i ∗ i i + j 王妃抓到白鼠,dp[i][j] = i*\frac i{i+j} dp[i][j]=ii+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][j3]i+jji+j1j1i+j2j2
  • 王 妃 抓 到 黑 鼠 , 龙 抓 完 跑 掉 白 鼠 , 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[i1][j2]i+jji+j1j1i+j2i

#include 
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;
}

你可能感兴趣的:(概率DP)