首页 > 解决方案 > Python - 6 个或更多尾部/头部代码的概率

问题描述

我让我的学生在 comp sci 中编写一个代码来模拟掷硬币 100 次,并将结果存储在一个列表中。寻找连续 6 个正面(或更多)或 6 个反面(或更多)。如果您发现连胜,则认为试验成功。重复此实验 10,000 次。使用它来确定找到连续 6 个正面或 6 个反面的概率。

理论上这个概率应该是~80%。

编辑:我可能误解了这个理论概率。我在这里找到了这个概率:https ://math.stackexchange.com/questions/2736117/what-is-the-probability-of-getting-6-or-more-heads-or-tails-in-a-row-翻转后

我的代码给了我大约 54% 的概率,即连续获得 6 个的概率。但是,如果我连续获得 7、8、9 或更多,我的代码应该将其标记为成功,对吗?

我了解我的代码会检查 6 条牛排,但如果有 7、8、9 条……它仍然会将其标记为成功。一定有我在这里想念的东西......

附上我的代码:

import random
numberofstreaks = 0
for experimentnumber in range(10000):
    result = []
    for i in range(100):
        flip = random.randint(0,1)
        result.append(flip)
    
    for i in range(len(result)-6):
        if result[i:i+6] == ([0,0,0,0,0,0] or [1,1,1,1,1,1]):
            numberofstreaks += 1
            break
print(numberofstreaks)
print('Chance of steak:',(numberofstreaks/100))

注意:他们目前正在学习列表,这就是为什么他们的代码必须包含列表的使用。

提前谢谢!

标签: pythonstatisticsprobability

解决方案


据我了解,您的代码并未考虑给定 100 次投掷硬币中的多个条纹。您可以通过将 i 移动 6 位来实现这一点,一旦它发现一个条纹,这样它就不会将 > 6 的条纹算作多个条纹。


推荐阅读