Alice和Bob赌糖果 牛客 概率DP(赌徒破产模型)

Alice和Bob赌糖果

在这里插入图片描述

solution

f 0 = 0 , f n + m = 1 f_0=0,f_{n+m}=1 f0=0,fn+m=1

f i = ( 1 − p ) f i − 1 + p f i + 1 f_i=(1-p)f_{i-1}+pf_{i+1} fi=(1p)fi1+pfi+1

= > f i + 1 − f i = f i − f i − 1 =>f_{i+1}-f_i=f_i-f_{i-1} =>fi+1fi=fifi1

令 f i = g i f i + 1 = > g i = p 1 − ( 1 − p ) g i − 1 令f_i=g_if_{i+1}=>g_i=\frac{p}{1-(1-p)g_{i-1}} fi=gifi+1=>gi=1(1p)gi1p

= > f n = ∏ i = m n + m − 1 g i =>f_n=\prod\limits_{i=m}^{n+m-1}g_i =>fn=i=mn+m1gi

code

#include <bits/stdc++.h>
using namespace std;
#define double long double
int main() {
    int n, l, r; cin >> n >> l >> r;
    int m, L, R; cin >> m >> L >> R;
    if(m == 0) cout << "1.00000" << '\n';
    else if(n == 0) cout << "0.00000" << '\n';
    else {
        double ali = 0, bob = 0;
        for(int i = l; i <= r; ++ i) {
            for(int j = L; j <= R; ++ j) {
                if(i > j) ali ++;
                if(i < j) bob ++;
            }
        }
        if(ali == 0) cout << "0.00000" << '\n';
        else {
            double p = ali / (ali + bob);
            double q = 1.0 - p;
            vector<double> g(n + m + 1);
            for(int i = 1; i < n + m; ++ i) {
                g[i] = p / (1.0 - q * g[i - 1]);
            }
            double res = 1.0;
            for(int i = n; i < n + m; ++ i) res *= g[i];
            cout << fixed << setprecision(5) << res << '\n';
        }
    }
    return 0;
}
  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值