题目链接:

http://acm.hdu.edu.cn/contests/contest_showproblem.php?pid=1010&cid=459

找出公式,公式有实际意义,某种情形当重复做n次实验时会出现一次,即出现的概率为1/n,现在要想出现这种情形,平均要做多少次实验,显然平均要做n次。

说一个具体的,比如掷色子,有6个点,6个点随机等概率出现。掷一次色子出现1的概率为1/6,现在想掷出1来,平均要掷色子多少次,即次数的数学期望是多少。

可以证明:

设掷i次色子才出现1的概率为p[i],则有

p[1] = 1/6;

p[2] = (5/6) *(1/6);第一次没有出现

p[3] = (5/6)^2*(1/6)

`````

p[n] = (5/6)^n-1*(1/6);前n-1次没有出现

``````

所以次数的数学期望为sum(k*p[k]),(k>=1,k为自然数,可以取到无穷)  ,据观察,有p[i] = p[i-1]*(5/6);

式子1:s = 1*p[1] + 2*p[2] + ``` +n*p[n] +````

式子2:(5/6)*s =     1*p[1] + ````(n-1)*p[n]+````(式子2为式子1的左右两边同时乘以5/6得到)

用式子1-式子2得

(1/6)*s = 1/6 + (1/6)*(5/6) + (1/6)*(5/6)^2````+(1/6)*(5/6)^n+```

又等比数列的公式得(1/6)*s =( 1/6(1 -(5/6)^n)/(1-5/6).由于n为正无穷,所有(5/6)^n =0;所以s = 6.

这个题的公式为:

情形1,出现连续n个相同后停止掷色子的次数的期望 = 1+m+m^2 + ``` + m^(n-1);

情形2,出现连续n个不同后停止掷色子的次数的期望 = 1+m/(m-1) + m^2/((m-1)*(m-2))+```+m^(n-1)/((m-1)*(m-2)*```*(m-n+1));

可以这样解释,情形1,先随便掷色子一次,后面要掷出和这个相同的期望数为m,然后仍要掷出相同的期望为m^2```

类推,后面要掷出和这个色子同色的概率为1/m,所以次数的期望为m。第三次掷色子要和前两次相同的概率为1/(m*m),所以期望为m*m```

其余就自己推吧···(未必对···)

另外一种方法:概率dp,摘自杭电解题报告

设dp[i]表示当前在 已经投掷出 i个 不相同/相同 这个状态时期望还需要投掷多少次,然后dp[i] 有如下等式:

相同:

//dp[0] = 1 + dp[1]

//dp[1] = 1 + ((m-1)dp[1] + dp[2]) / m

//dp[i] = 1 + ((m-1)dp[1] + dp[i+1]) / m

//...

//dp[n] = 0;

不相同:

//dp[0] = 1 + dp[1]

//dp[1] = 1 + (dp[1] + (m-1) dp[2]) / m

//dp[2] = 1 + (dp[1] + dp[2] + (m-2) dp[3]) / m

//dp[i] = 1 + (dp[1] + dp[2] + ... dp[i] + (m-i)dp[i+1]) / m

//...

//dp[n] = 0;

。。于是可以高斯消元。。对于第一问。。我们发现就是相当于 Typing Monkey 问题中字符串是 AAAA..AA 这一特殊情况。。解得递推式:

dp[n] = 0

dp[n-1] = dp[n] * m + 1

。。。

解开后等于等比数列求和。

(也可以直接得到这个公式。。。因为在当前状态只有 m/1 的概率可以进入下一状态,否则要重新来过。。而这一步会另总的步数 + 1。)

对于第二问。。

现在设s[i]=sigma{dp[i], 1..i},对s[i] 列方程
每个方程是关于三个相邻的s[i] 的,然后就可以线性时间解出来了。

也可以设 d[i] = dp[i] - dp[i+1].

可以得到 d[i] =  m * d[i-1]  / (m-i)

然后就是解一元一次方程...

参见:

http://acm.hust.edu.cn/vjudge/problem/viewProblem.action?id=13614

http://acm.hust.edu.cn/vjudge/problem/viewProblem.action?id=21631

http://acm.hust.edu.cn/vjudge/problem/viewProblem.action?id=24402

http://www.cnblogs.com/ch3656468/archive/2011/05/04/2036332.html

上面的两种递推式肯定能推出上面的公式来,所以我直接用公式写的

贴代码:

  1. #include <cstdio>
  2. int main()
  3. {
  4. // freopen("in.c","r",stdin);
  5. int t;
  6. while(scanf("%d",&t) != EOF)
  7. {
  8. while(t--)
  9. {
  10. double flag,m,n;
  11. scanf("%lf%lf%lf",&flag,&m,&n);
  12. double ans=,tmp =;
  13. if(flag == )
  14. {
  15. for(int i=; i<n; ++i)
  16. {
  17. tmp *= m;
  18. ans += tmp;
  19.  
  20. }
  21. }
  22. else
  23. {
  24. for(int i=; i<n; ++i)
  25. {
  26. tmp *= (m/(m-i));
  27. ans += tmp;
  28. }
  29. }
  30. printf("%lf\n",ans);
  31. }
  32. }
  33. return ;
  34. }

dice 概率论 概率DP的更多相关文章

  1. hdu 4625 Dice(概率DP)

    Dice Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/65536 K (Java/Others) Total Submi ...

  2. hdu 4586 Play the Dice(概率dp)

    Problem Description There is a dice with n sides, which are numbered from 1,2,...,n and have the equ ...

  3. HihoCoder - 1339 Dice Possibility(概率dp)

    题意:求用N(1<=N<=100)个骰子掷出M(1<=M<=600)的概率 分析:直接求概率可能出现6^100次方,会爆精度.可以用一个数组dp[i][j]记录用i个骰子掷出j ...

  4. HihoCoder1339 Dice Possibility(概率DP+母函数)

    时间限制:10000ms 单点时限:1000ms 内存限制:256MB 描述 What is possibility of rolling N dice and the sum of the numb ...

  5. HDU 4652 Dice (概率DP)

    版权声明:欢迎关注我的博客,本文为博主[炒饭君]原创文章,未经博主同意不得转载 https://blog.csdn.net/a1061747415/article/details/36685493 D ...

  6. Dice (III) 概率dp

    #include <cstdio> #include <iostream> #include <cstring> #include <algorithm> ...

  7. Throwing Dice(概率dp)

    C - Throwing Dice Time Limit:2000MS     Memory Limit:32768KB     64bit IO Format:%lld & %llu Lig ...

  8. HDU 4599 Dice (概率DP+数学+快速幂)

    题意:给定三个表达式,问你求出最小的m1,m2,满足G(m1) >= F(n), G(m2) >= G(n). 析:这个题是一个概率DP,但是并没有那么简单,运算过程很麻烦. 先分析F(n ...

  9. SPOJ Favorite Dice(概率dp)

    题意: 一个骰子,n个面,摇到每一个面的概率都一样.问你把每一个面都摇到至少一次需要摇多少次,求摇的期望次数 题解: dp[i]:已经摇到i个面,还需要摇多少次才能摇到n个面的摇骰子的期望次数 因为我 ...

随机推荐

  1. URAL 1635 Mnemonics and Palindromes

    URAL 1635 思路:区间dp+贪心,先n^2处理出每段区间是否是回文串,然后贪心地找每一段1到i的最少分割. 代码: #include<bits/stdc++.h> using na ...

  2. CodeSmith无法获取Oracle表注释

    如题:安装CodeSmith5.2版本,SQLServer没有任何问题,而Oracle就只能获取列的注释而不能获取表的注释,经过多方面查找资料后找到了一个最重要的解决方案,Sql语句,如下:selec ...

  3. 关于pthread_cond_wait()使用的理解

    pthread_cond_wait()是linux多线程同步实现的一种方法,表示等待某一个线程共享变量满足了某种情况时 线程才能继续执行 pthread_cond_wait()之后的代码,如下面的示例 ...

  4. Java字符串 API

    常用API

  5. vuecli3 引入script 针对没有cmd amd require等方式的js

    最近做高德开发,需要引入高德的js,但是 说实话 高德官方的文档不知道大佬们有没有看懂,反正我是没看懂,写的都什么鬼?我怎么引都引入不了,迫不得已想到了如下方法: 一.准备一个能够在页面中插入js的方 ...

  6. 使用API失效供应商地址Demo(转)

    原文地址  使用API失效供应商地址Demo DECLARE lv_return_status ) := NULL; ln_msg_count NUMBER; lv_errmsg ); lt_vend ...

  7. 点击input文字会自动消失

    <input type="text" name="q" value="请输入关键字" style="width:128px; ...

  8. javaScript 删除确认实现方法小结

    第一种: <a href="javascript:if(confirm('确认删除吗?'))window.location='del.php'">删除</a> ...

  9. 深入理解$watch ,$apply 和 $digest --- 理解数据绑定过程——续

    Angular什么时候不会自动为我们$apply呢? 这是Angular新手共同的痛处.为什么我的jQuery不会更新我绑定的东西呢?因为jQuery没有调用$apply,事件没有进入angular ...

  10. forget word out a~4

    1● ana 错误,分开   2● ante   先,前面   3● anti 反对,相反       1◆ ana 2◆ ante 3◆ anti     1● dem(o) 2● pupl 3● ...