蒙提霍尔游戏模拟
最简易的代码———初学者适用
蒙提霍尔游戏的大致内容:
参赛者会看见三扇关闭了的门,其中一扇的后面有一辆汽车,选中后面有车的那扇门就可以赢得该汽车,而另外两扇门后面则各藏有一只山羊。当参赛者选定了一扇门,但未去开启它的时候,节目主持人会开启剩下两扇门的其中一扇,露出其中一只山羊。主持人其后会问参赛者要不要换另一扇仍然关上的门。悖论问题是:换另一扇门会否增加参赛者赢得汽车的机会率?
其中推算概率的流程:(由于图片错误,第二次选择的成功的概率均为1/6)
为了模拟蒙提霍尔游戏算法分析
可以把游戏过程分为4个问题来实现
1.奖励门的随机(我们将分别设计奖励门为0,1,2的情况)
2.打开其中一扇门露出一只羊(不能是参赛者选择的门)
3.是否更换另一扇门
4.导出结果
下面展示源代码
import random
prize =random.randint(1, 3)#奖励门的随机
a=0
choose = int(input("请输入数字0-2以表示您所选择的门:"))
if prize == 1:
door = ['goat', 'goat', 'car']
while a==0:
init_choice= random.randint(0, 1)
if init_choice!=choose:#打开一扇后面是山羊的门且不能是参赛者选择的门
a=1
else :a=0
print(init_choice)
print(door[init_choice])
change = int(input("是否需要更换另一扇门,温馨提示:输入1更换输入,2不更换"))#是否更换另一扇门
if change == 1:
if door[choose]=="car":
print('goat')
else:print('car')
elif change == 2:
print(door[choose])
elif prize == 2:
door = ['car', 'goat', 'goat']
while a==0:
init_choice= random.randint(1, 2)
if init_choice!=choose:
a=1
else :a=0
print(init_choice)
print(door[init_choice])
change = int(input("是否需要更换另一扇门,温馨提示:输入1更换输入,2不更换"))
if change == 1:
if door[choose]=="car":
print('goat')
else:print('car')
elif change == 2:
print(door[choose])
elif prize == 3:
door = ['goat', 'car', 'goat']
while a==0:
from random import choice
f = [0, 2]
init_choice = choice(f)#从列表里选择一个随机数
if init_choice!=choose:
a=1
else :a=0
print(init_choice)
print(door[init_choice])
change = int(input("是否需要更换另一扇门,温馨提示:输入1更换输入,2不更换"))
if change == 1:
if door[choose]=="car":
print('goat')
else:print('car')
elif change == 2:
print(door[choose])