社区所有版块导航
Python
python开源   Django   Python   DjangoApp   pycharm  
DATA
docker   Elasticsearch  
aigc
aigc   chatgpt  
WEB开发
linux   MongoDB   Redis   DATABASE   NGINX   其他Web框架   web工具   zookeeper   tornado   NoSql   Bootstrap   js   peewee   Git   bottle   IE   MQ   Jquery  
机器学习
机器学习算法  
Python88.com
反馈   公告   社区推广  
产品
短视频  
印度
印度  
Py学习  »  Python

python中的简单monte carlo模拟

Adam • 5 年前 • 2187 次点击  

你需要多少次掷骰子直到你看到每一个数字?

我被要求定义一个函数来运行蒙特卡罗模拟,该模拟返回上述问题的估计值。我对解决方案的理解是,我需要:

  1. 定义一个以试验次数为输入的函数
  2. 生成1到6之间的随机整数(模具上的边数)
  3. 如果该整数不在列表中,则将其存储在列表中
  4. 计算达到所述条件所需的试验次数,并返回该计数

我对编程,特别是python还比较陌生,所以我很难确定为什么在调用函数时我的语法不产生输出,我希望有人能帮助我朝着正确的方向前进

这是我的代码:

def roll(n=1000):
    trials = []
    sides = 6
    start = 1

    for i in range (n):
        for x in range (sides):
            collection = [random.randint(1,sides)]
            while any([x not in collection]):
            collection.append(random.randint(1,6))
            trials.append(len(collection))

    return sum(trials)/ len(trials)
Python社区是高质量的Python/Django开发社区
本文地址:http://www.python88.com/topic/42983
 
2187 次点击  
文章 [ 3 ]  |  最新文章 5 年前