统计学三门问题实际执行案例Python代码【10000次模拟执行选择交换或者不交换】

案例来源

赤裸裸的统计学提到的三门问题,参赛者会看见三扇关闭了的门,其中一扇的后面有一辆汽车,选中后面有车的那扇门可赢得该汽车,另外两扇门后面则各藏有一只山羊。当参赛者选定了一扇门,但未去开启它的时候,节目主持人开启剩下两扇门的其中一扇,露出其中一只山羊。主持人其后会问参赛者要不要换另一扇仍然关上的门。问题是:换另一扇门是否会增加参赛者赢得汽车的机率。如果严格按照上述的条件,那么答案是会。不换门的话,赢得汽车的几率是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的目标

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值