平均要取多少个(0,1)中的随机数才能让和超过1

简介:

先用程序估算一下

复制代码
from __future__ import division
import random
N = 1000000
sums = 0
for i in range(N):
    count = 0
    s = 0
    while 1:
        s += random.random()
        count += 1
        if s > 1:
            sums += count 
            break
print sums / N
复制代码

三次给出的结果分别是

1
2.716957 2.718334  2.71885

2.718不就是e的味道吗,下面证明一下

先取两个特例

特例1:x+y < 1——两个随机数之和小于1

结果是紫色部分,为1/2

特例2:x+y+z< 1——三个随机数之和小于1

结果为深底下面的,占整个体积的1/6(锥体积:1/3*底面积*好=1/3 * 1/2 * 1 *1)

这个 1/6 可以利用截面与底面的相似比关系,通过简单的积分求得:

   ∫(0..1) (x^2)*1/2 dx = 1/6

推广:四个 0 到 1 之间的随机数之和小于 1 的概率就等于四维立方体一角的“体积”,它的“底面”是一个体积为 1/6 的三维体,在第四维上对其进行积分便可得到其“体积”

  ∫(0..1) (x^3)*1/6 dx = 1/24

依此类推, n 个随机数之和不超过 1 的概率就是 1/n! ,反过来 n 个数之和大于 1 的概率就是 1 – 1/n! ,因此加到第 n 个数才刚好超过 1 的概率就是

 (1 – 1/n!) – (1 – 1/(n-1)!) = (n-1)/n!

因此,要想让和超过 1 ,需要累加的期望次数为

       ∑(n=2..∞) n * (n-1)/n! = ∑(n=1..∞) n/n! = e

 

转自:http://www.matrix67.com/blog/archives/3507






本文转自jihite博客园博客,原文链接:http://www.cnblogs.com/kaituorensheng/p/3946384.html,如需转载请自行联系原作者

相关文章
|
6月前
1023 组个最小数 (20 分)
1023 组个最小数 (20 分)
|
7月前
leetcode-2006:差的绝对值为 K 的数对数目
leetcode-2006:差的绝对值为 K 的数对数目
66 0
|
7月前
919: 我们被平均了
919: 我们被平均了
1186:出现次数超过一半的数
1186:出现次数超过一半的数
121 0
|
算法 C++ Python
【每日算法Day 90】5种方法:求解数组中出现次数超过一半的那个数
【每日算法Day 90】5种方法:求解数组中出现次数超过一半的那个数
182 0
|
Python
LeetCode 2006. 差的绝对值为 K 的数对数目
给你一个整数数组 nums 和一个整数 k ,请你返回数对 (i, j) 的数目,满足 i < j 且 |nums[i] - nums[j]| == k 。
102 0
|
移动开发 算法
数的范围的算法
数的范围的算法
h0039. 平方数 (15 分)
h0039. 平方数 (15 分)
136 0
统计正数和负数的个数然后计算这些数的平均值 (15 分)
统计正数和负数的个数然后计算这些数的平均值 (15 分)
276 0

热门文章

最新文章