Description

Tweetuzki 有一个袋子,袋子中有 \(N\) 个无差别的球。Tweetuzki 每次随机取出一个球后放回。求取遍所有球的期望次数。

取遍是指,袋子中所有球都被取出来过至少一次。

Input

一行一个整数 \(N\)

Output

一行一个整数,表示期望次数对 \(200403013\) 取模的结果

Hint

\(1~\leq~N~\leq~10^7\)

Solution

期望嘛,就是你xjb乱推好几个看起来很靠谱事实上最多有一个是对的甚至可能一个也不对的式子,然后用蒙特卡洛方法拍一拍,挑一个最靠谱的交上去

感谢@_rqy提供指导

先给出结论:

\[E(n)~=~n~\times~(\sum_{i=1}^{n}~\frac{1}{i})
\]

证明如下:

引理:对于一次试验,有 \(p~(0~\leq~p~\leq~1)\) 的概率成功,有 \(1-p\) 的概率不成功,如果一次试验后不成功则重复进行试验,否则停止。则期望在 \(\frac{1}{p}\) 步后停止试验

证明:

设期望 \(x\) 步后停止试验,根据已知以及期望的线性相加性,可得方程:

\[x~=~1~+~p~\times~0~+~(1~-~p)~\times~x
\]

上述方程的直观解释是当前进行完一步后有 \(p\) 的概率再进行 \(0\) 次(停止),\(1~-~p\) 的概率继续进行,由于下次试验和这次试验完全相同,所以有 \(1~-~p\) 的概率期望再进行 \(x\) 次。

解方程,得

\[x~=~\frac{1}{p}
\]

引理证毕。

于是考虑摸球,首先有 \(n\) 个球没有被摸到的时候,摸一次摸到新球的概率为 \(1\),根据引理,期望摸 \(1\) 次。

然后剩下 \(n~-~1\) 个球没有被摸到,摸一次摸到新球的概率为 \(\frac{n-1}{n}\),根据引理,期望摸 \(\frac{n}{n-1}\) 次。

然后剩下 \(n~-~2\) 个球没有摸到,摸一次摸到新球的概率为 \(\frac{n-2}{n}\) ,根据引理,期望摸 \(\frac{n}{n-2}\) 次。

……(一位读者及时砸坏了复读机,停止了复读)

按照球的个数进行数学归纳,根据期望的可加性(非线性相加性),可以得到摸遍 \(n\) 个球的期望

\[E(n)~=~n~+~\frac{n}{n-1}~+~\frac{n}{n-1}~+~\dots~+~\frac{n}{1}
\]

提取公因数 \(n\),可得

\[E(n)~=~n~\times~(\sum_{i=1}^{n}~\frac{1}{i})
\]

证毕。

然鹅最后一个式子只是为了让结论变得优美一点,事实上用倒数第二个式子就可以做题了233

于是先筛一遍逆元,然后求答案即可。

Code

  1. #include <cstdio>
  2. #ifdef ONLINE_JUDGE
  3. #define freopen(a, b, c)
  4. #endif
  5. #define rg register
  6. #define ci const int
  7. #define cl const long long
  8. typedef long long int ll;
  9. namespace IPT {
  10. const int L = 1000000;
  11. char buf[L], *front=buf, *end=buf;
  12. char GetChar() {
  13. if (front == end) {
  14. end = buf + fread(front = buf, 1, L, stdin);
  15. if (front == end) return -1;
  16. }
  17. return *(front++);
  18. }
  19. }
  20. template <typename T>
  21. inline void qr(T &x) {
  22. rg char ch = IPT::GetChar(), lst = ' ';
  23. while ((ch > '9') || (ch < '0')) lst = ch, ch=IPT::GetChar();
  24. while ((ch >= '0') && (ch <= '9')) x = (x << 1) + (x << 3) + (ch ^ 48), ch = IPT::GetChar();
  25. if (lst == '-') x = -x;
  26. }
  27. template <typename T>
  28. inline void ReadDb(T &x) {
  29. rg char ch = IPT::GetChar(), lst = ' ';
  30. while ((ch > '9') || (ch < '0')) lst = ch, ch = IPT::GetChar();
  31. while ((ch >= '0') && (ch <= '9')) x = x * 10 + (ch ^ 48), ch = IPT::GetChar();
  32. if (ch == '.') {
  33. ch = IPT::GetChar();
  34. double base = 1;
  35. while ((ch >= '0') && (ch <= '9')) x += (ch ^ 48) * ((base *= 0.1)), ch = IPT::GetChar();
  36. }
  37. if (lst == '-') x = -x;
  38. }
  39. namespace OPT {
  40. char buf[120];
  41. }
  42. template <typename T>
  43. inline void qw(T x, const char aft, const bool pt) {
  44. if (x < 0) {x = -x, putchar('-');}
  45. rg int top=0;
  46. do {OPT::buf[++top] = x % 10 + '0';} while (x /= 10);
  47. while (top) putchar(OPT::buf[top--]);
  48. if (pt) putchar(aft);
  49. }
  50. const int maxn = 10000010;
  51. const int MOD = 20040313;
  52. int n, ans;
  53. int inv[maxn];
  54. void GetInv();
  55. int main() {
  56. freopen("1.in", "r", stdin);
  57. qr(n);
  58. GetInv();
  59. for (rg int i = 0; i < n; ++i) {
  60. ans = (ans + 1ll * n * inv[n - i]) % MOD;
  61. }
  62. qw(ans, '\n', true);
  63. }
  64. void GetInv() {
  65. inv[1] = 1;
  66. for(int i = 2; i <= n; ++i) inv[i] = 1ll * (MOD - MOD / i) * inv[MOD % i] % MOD;
  67. }

Summary

对于一次试验,有 \(p~(0~\leq~p~\leq~1)\) 的概率成功,有 \(1-p\) 的概率不成功,如果一次试验后不成功则重复进行试验,否则停止。则期望在 \(\frac{1}{p}\) 步后停止试验

【期望】【P5081】Tweetuzki 爱取球的更多相关文章

  1. [洛谷P5081]Tweetuzki 爱取球

    题目大意:有$n$个球,每一次取一个球然后放回,问期望多少次取遍所有球 题解:令$f_i$表示已经取了$i$种球,还要取的次数的期望.$f_i=\dfrac in(f_i+1)+\dfrac{n-i} ...

  2. THUSC2019 退役记

    Day -inf 这一个半月潜心搞文化课,把文化课的坑填上了不少,我文化课的底子真是薄啊 一年前没想过我还挺有希望进队的,最后还差点冲上 一年后说不定会发现我搞文化课也能搞得不错呢? 一切都是未知 t ...

  3. [BZOJ4204] 取球游戏(期望)

    DarkBZOJ4204 (题面来源) [题目描述] 有\(m\)个球,一开始每个球均有一个初始标号,标号范围为\(1-n\)且为整数,标号为\(i\)的球有\(a_{i}\)个,并保证\(Σa_{i ...

  4. [学习笔记]概率&期望

    概率的性质 非负性:对于每一个事件$A,0\;\leq\;P(A)\;\leq\;1$. 规范性:对于必然事件$S,P(S)=1$;对于不可能事件$A,P(A)=0$. 容斥性:对于任意两个事件$A, ...

  5. HDU 5810 Balls and Boxes(盒子与球)

     Balls and Boxes(盒子与球) Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/65536 K (Java/O ...

  6. lightoj 1408 Batting Practice (概率问题,求期望,推公式)

    题意:一个人若连续进k1个球或连续不进k2个球,游戏结束,给出这个人不进球的概率p(注意:是不进球!!!),求到游戏结束时这个投球个数的期望. 不进球概率为p,进概率 q=1-p.设 f[i] 表示连 ...

  7. Tsinsen-A1489 抽奖 【数学期望】

    乔明达太神,其实已经题解非常清楚了,我再推一遍吧. 题目意思相当于有n个盒子,无差别投m次球,每个盒子的得分为每个盒子里的球的个数. 第一问: 假设这个球放在了第i个盒子里,那么 ∆ans = (mi ...

  8. TsinsenA1489 抽奖 【期望】

    题目分析: 问题可以转化成将m个球放进n个盒子里,每个盒子的贡献为盒子中球数的平方. 第一问考虑增量. 对于一个原本有$x$个球的盒子,新加一个球的贡献是$2x+1$.期望条件下仍然满足. 第$i$个 ...

  9. BZOJ2554 color 【概率DP】【期望DP】

    题目分析: 好题. 一开始看错题了,以为是随机选两个球,编号在前的染编号在后的. 但这样仍然能获得一些启发,不难想到可以确定一个颜色,剩下的颜色是什么就无关了. 那么答案就是每种颜色的概率乘以期望.概 ...

随机推荐

  1. selenium、unittest——POM框架并出报告

    学习隔壁大神的POM框架,结合自己的用例进行修改整理并执行,操作遇到的主要问题是如何分布的写各个模块并统一运行,每个文件夹想要import里面的模块需要有__init__模块 POM主要分为三个部分, ...

  2. Jenkins Git安装设置

    Jenkins Git安装设置 在此安装中,必须确保Internet连接可连接其安装 Jenkins 机器.在 Jenkins 仪表盘(主屏幕)的左侧单击 Manage Jenkins 选项.打开网址 ...

  3. Digital Roots:高精度

    C - Digital Roots Description The digital root of a positive integer is found by summing the digits ...

  4. Python科学计算库灬numpy

    Numpy NumPy是一个功能强大的Python库,主要用于对多维数组执行计算.Numpy许多底层函数实际上是用C编写的,因此它的矩阵向量计算速度是原生Python中无法比拟的. numpy属性 维 ...

  5. Docker 快速入门教程

    本文目的是给几乎从未接触过docker,或者仅仅是听说或者通过新闻了解过Docker的同学 通过一个已有的Docker仓库构建和提交自己的Docker 镜像 这里会涉及到一些概念,但是不单独介绍 这里 ...

  6. testng系列-ReportNG

    生成reportng报告操作步骤: 一.maven的pom.xml文件需要添加内容: <properties> <!-- maven 参数配置,这里引用不同的testng.xml - ...

  7. New begin

    Purpose 今天更换了id,希望重新沉淀. 晚上看到国外一个博客,落款有个中文: 敬惜字纸. 共勉.

  8. 3. IP地址转换函数

    一.字符串表示的IP地址需要被转化为整数(二进制数)方能使用 IPv4地址:点分十进制字符串 IPv6地址:十六进制字符串 有时(如记录日志),我们则要把整数(二进制数)表示的IP地址转化为可读的字符 ...

  9. MySQL的课堂的实践

    MySQL的课堂的实践 基本认识 如今的数据库有几种是主流,分别是:Oracle Database.Informix.SQL Server.PostgreSQL.MySQL等,我们现在学习的MySQL ...

  10. 针对某一网站的UI进行分析

    本周课上教学通过对PM(项目经理)的学习,我了解到PM 对项目所有功能的把握, 特别是有关的UI内容.最差的UI, 体现了团队的组织架构:其次, 体现了产品的内部结构:最好, 体现了用户的自然需求. ...