首页 > 其他 > 详细

Codeforces Round #259 (Div. 1)——Little Pony and Expected Maximum

时间:2014-08-02 12:57:13      阅读:322      评论:0      收藏:0      [点我收藏+]

题目连接

  • 题意:
    输入n、m,表示一个n面的色子(面上的值为1-n),投掷m次,求得到的最大值的期望(1?≤?m,?n?≤?105).
  • 分析:
    假设当前得到的最大值是Max,那么对应的概率是:sigma(C(m,k) * ((1 / n) ^ k )*(((Max - 1) / n) ^ (m - k)) ),(1 <= k <= n);化简就可以得到:sigma(C(m,k) * ((1 / n) ^ k )*(((Max - 1) / n) ^ (m - k)) ) - ((Max - 1) / n) ^ m,(0 <= k <= n);前半部分由二项式可以得到Max ^ m,那么化简结果就是Max ^ m - (Max - 1) ^ m。最后再乘以Max就是期望了。Max可以采用枚举的方式
    感叹一下,才发现pow函数和快速幂的效率是一样的。。
int main ()
{
    int n, m;
    while (~RII(n, m))
    {
        double ans = 0;
        FE(Max, 1, n)
        {
            ans += Max * (pow((double)Max / n, m) - pow((Max - 1.0) / n, m));
        }
        printf("%.10f\n", ans);
    }
    return 0;
}


Codeforces Round #259 (Div. 1)——Little Pony and Expected Maximum,布布扣,bubuko.com

Codeforces Round #259 (Div. 1)——Little Pony and Expected Maximum

原文:http://blog.csdn.net/wty__/article/details/38345949

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!