BZOJ1426: 收集邮票 期望DP

Posted ONION_CYC

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了BZOJ1426: 收集邮票 期望DP相关的知识,希望对你有一定的参考价值。

【题意】有n种不同的邮票,第i次可以花i元等概率购买到一种邮票,求集齐n种邮票的期望代价。n<=10^4。

【算法】期望DP

【题解】首先设g[i]表示已拥有i张邮票集齐的期望购买次数,根据全期望公式,可以依赖于买到已集和未集邮票的情况:

$$g[i]=\\frac{i}{n}*g[i]+\\frac{n-i}{n}*g[i+1]+1$$

当然最后记得+1,然后移项解方程。

设f[i]表示已拥有i张邮票及其的期望代价,会发现因为是倒推,所以代价的问题变得很麻烦。

我们将代价倒置,假设购买k次,那么第一张k元……第k张1元,那么就会发现代价变成了集齐的期望购买次数。

根据全期望公式:

$$f[i]=\\frac{i}{n}*(f[i]+g[i])+\\frac{n-i}{n}*(f[i+1]+g[i+1])+1$$

然后移项解方程即可。

复杂度O(n)。

也可以直观地设计状态(不倒置代价),然后计算无穷:DaD3zZ

#include<cstdio>
double f[10010],g[10010],n;
int main()
{
    scanf("%lf",&n); 
    for(int i=n-1;i>=0;i--)f[i]=f[i+1]+n/(n-i);
    for(int i=n-1;i>=0;i--)g[i]=g[i+1]+f[i+1]+i*f[i]/(n-i)+n/(n-i);
    printf("%.2lf",g[0]);
    return 0;
}
View Code

 

以上是关于BZOJ1426: 收集邮票 期望DP的主要内容,如果未能解决你的问题,请参考以下文章

BZOJ1426: 收集邮票 期望DP

bzoj 1426: 收集邮票期望dp

BZOJ 1426 收集邮票 ——概率DP

BZOJ1426: 收集邮票

BZOJ1426收集邮票 期望

bzoj 1426:收集邮票 求平方的期望