利用有放回抽样估计自然常数e python

利用有放回抽样估计自然常数e python


有放回抽样中,当抽样次数n等于样本数量,且趋近于正无穷时,一个数字没有被抽到的概率如下
lim ⁡ n → ∞ ( 1 − 1 n ) n = 1 e \lim_{n \to \infty} (1-\frac{1}{n} )^n=\frac{1}{e} nlim(1n1)n=e1

可以利用这一点估计e的值

由于我暑假闲的无聊,想巩固一下学的python,故写了三种不同的版本,分别利用集合set,字典dict,还有numpy的ndarray

一开始用的字典,发现python是真的慢,1e8线性时间复杂度都要用上个十几秒

我还以为是我打开方式不对,尝试了三种版本后发现都要十几秒,最后又一次直观的感受到了python的慢

运行结果

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

代码

字典版

import pandas as pd 
import numpy as np
import time
time_start = time.time()  # 记录开始时间
d={}
n=10000000
cnt=0
for i in range(n):
    num=random.randint(0,n-1)
    if d.get(num,0)==0:
        d[num]=1
    else:
        cnt=cnt+1
print(n/cnt)
time_end = time.time()  # 记录结束时间
time_sum = time_end - time_start  # 计算的时间差为程序的执行时间,单位为秒/s
print(time_sum)

numpy版

import pandas as pd 
import numpy as np
import time
time_start = time.time()  # 记录开始时间
n=10000000
d=np.zeros(n, dtype = int)
cnt=0
for i in range(n):
    num=random.randint(0,n-1)
    if d[num]==0:
        d[num]=d[num]+1
    else:
        d[num]=d[num]+1
        cnt=cnt+1
print(n/cnt)
time_end = time.time()  # 记录结束时间
time_sum = time_end - time_start  # 计算的时间差为程序的执行时间,单位为秒/s
print(time_sum)

set版

import pandas as pd 
import numpy as np
import time
time_start = time.time()  # 记录开始时间
n=10000000
d=set()
for i in range(n):
    num=random.randint(0,n-1)
    d.add(num)
print(n/(n-len(d)))
time_end = time.time()  # 记录结束时间
time_sum = time_end - time_start  # 计算的时间差为程序的执行时间,单位为秒/s
print(time_sum)
  • 5
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 6
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 6
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值