博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
平均要取多少个(0,1)中的随机数才能让和超过1
阅读量:4617 次
发布时间:2019-06-09

本文共 855 字,大约阅读时间需要 2 分钟。

先用程序估算一下

from __future__ import divisionimport randomN = 1000000sums = 0for i in range(N):    count = 0    s = 0    while 1:        s += random.random()        count += 1        if s > 1:            sums += count             breakprint sums / N

三次给出的结果分别是

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

 

转自:

转载于:https://www.cnblogs.com/kaituorensheng/p/3946384.html

你可能感兴趣的文章
C语言学习笔记--字符串
查看>>
CSS-上下文选择器
查看>>
ionic repeat 重复最后一个时要执行某个函数
查看>>
1.初识代码审计-基础
查看>>
[Vue-rx] Stream an API using RxJS into a Vue.js Template
查看>>
解决VC几个编译问题的方法——好用
查看>>
SPOJ #11 Factorial
查看>>
City Upgrades
查看>>
“人少也能办大事”---K2 BPM老客户交流会
查看>>
关于七牛进行图片添加文字水印操作小计
查看>>
DataSource数据库的使用
查看>>
Luogu4069 SDOI2016 游戏 树链剖分、李超线段树
查看>>
Java的内部类真的那么难以理解?
查看>>
一文搞懂Java环境,轻松实现Hello World!
查看>>
hash实现锚点平滑滚动定位
查看>>
也谈智能手机游戏开发中的分辨率自适应问题
查看>>
关于 IOS 发布的点点滴滴记录(一)
查看>>
《EMCAScript6入门》读书笔记——14.Promise对象
查看>>
CSS——水平/垂直居中
查看>>
Eclipse连接mysql数据库jdbc下载(图文)
查看>>