文章目录
案例来源
赤裸裸的统计学提到的三门问题,参赛者会看见三扇关闭了的门,其中一扇的后面有一辆汽车,选中后面有车的那扇门可赢得该汽车,另外两扇门后面则各藏有一只山羊。当参赛者选定了一扇门,但未去开启它的时候,节目主持人开启剩下两扇门的其中一扇,露出其中一只山羊。主持人其后会问参赛者要不要换另一扇仍然关上的门。问题是:换另一扇门是否会增加参赛者赢得汽车的机率。如果严格按照上述的条件,那么答案是会。不换门的话,赢得汽车的几率是1/3。换门的话,赢得汽车的几率是2/3。
简单实现python代码
import random
def simulate_choice(number,flag):
# 初始化选项,假设选项0是正确的
correct_option = 0
options = [correct_option, 1, 2]
# bujiaohuan=0 代表不交换正确的数据
# 直接用a表示正确 b表示不正确
a = 0
b = 0
flag = flag
result=[]
# 用户随机选择一个选项
for i in range(number):
initial_choice = random.choice(options)
#N FLAG=Y代表换 FLAG=N代表不换
# 排除一个错误选项
remaining_options = [x for x in options if x != initial_choice]
#x for x in options 遍历options列表中的每一个元素,每次遍历都将当前元素的值赋给变量x
#这行代码是Python中的列表推导式
#if x != initial_choice:这是一个条件表达式,用于筛选出那些不等于initial_choice的元素
# 用于筛选2个不在选择中的选项 那就是
print(remaining_options)
if correct_option in remaining_options:
# 正确的值还在里面,那么就就要去掉这里面那个错误的选项
# 这一步去掉错误的
if flag=='Y':
# 如果去掉了,那就说明第一次绝对选错了,这个时候只有换才能是对
a+=1
print(f"Y的情况下成功{a}")
else:
# 如果是不换的话,那就代表已经没有机会了,直接B+,也就是一次错误数据
b+=1
print(f"Y的情况下失败{b}")
else:
# 第一次选择正确的情况下如果再交换,那么必定是失败了
if flag=='Y':
b+=1
else:
# 就是如果选择不交换
a+=1
result.append(number)
result.append(a)
result.append(b)
return result
result_with_change = simulate_choice(10000,"Y")
print(result_with_change)
补充
这是简单的模拟执行多次,最后的分布结果可以查
第一次运行:
第二次运行:
基本符合实际换门的话,赢得汽车的几率是2/3的目标