【题解】黑白球

题目描述

  一个箱子里面有n个黑球m个白球。你每小时都随机从箱子里面抽出两个小球,然后把这两个球都染成黑球,然后再放回去。问需要多少小时才能把所有小球变成黑色小球?输出期望值。

 

输入输出格式

输入格式

  多组测试数据。

   第一行,一个整数G,表示有G组测试数据。1 <= G <= 10

   每组测试数据格式如下:

    一行,两个整数,nm1 <=n,m<=47

 

输出格式

  共G行,每行一个实数。误差不能超过0.00001

输入输出样例

输入样例

5

1 1

2 1

1 2

4 7

1 3

 

输出样例

1.0

1.5

2.0

13.831068977298521

3.4

 

题解

  设$sum=n+m$,设$dp[i]$为有$i$个黑球的情况下,把所有球都变成黑色小球的期望值。

  易得$dp[i]=dp[i]\times\frac{i(i-1)}{sum(sum-1)}+dp[i+1]\times(1-\frac{i(i-1)}{sum(sum-1)}-\frac{(sum-i)(sum-i-1)}{sum(sum-1)})+dp[i+2]\times\frac{(sum-i)(sum-i-1)}{sum(sum-1)}+1$

  整理得$dp[i]=\frac{dp[i+1]\times(1-\frac{i(i-1)}{sum(sum-1)}-\frac{(sum-i)(sum-i-1)}{sum(sum-1)})+dp[i+2]\times\frac{(sum-i)(sum-i-1)}{sum(sum-1)}+1}{1-\frac{i(i-1)}{sum(sum-1)}}$

   直接推即可。

#include <iostream>
#include <cstdio>

#define MAX_N (47 + 5) 
#define MAX_M (47 + 5)

#define BB(x) (((double)(x) / sum) * ((double)((x) - 1) / (sum - 1)))
#define WW(x) (((double)(x) / sum) * ((double)((x) - 1) / (sum - 1)))
#define BW(x, y) (1 - BB(x) - WW(y))

using namespace std;

int G;
int n, m, sum;
double dp[MAX_N + MAX_M];

int main()
{
    scanf("%d", &G);
    while(G--)
    {
        scanf("%d%d", &n, &m);
        sum = n + m;
        dp[sum] = dp[sum + 1] = 0;
        for(register int i = sum - 1, j = 1; i >= n; --i, ++j)
        {
            dp[i] = (dp[i + 1] * BW(i, j) + dp[i + 2] * WW(j) + 1) / (1 - BB(i));
        }
        printf("%lf\n", dp[n]);
    }
    return 0;
}
参考程序

 

转载于:https://www.cnblogs.com/kcn999/p/10645121.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值