用贝叶斯定理解决三门问题并用Python进行模拟(Bayes' Rule Monty Hall Problem Simulation Python)
三门问题(Monty Hall problem)也称为蒙提霍尔问题或蒙提霍尔悖论,出自美国的电视游戏节目《Let’s Make a Deal》。问题名字来自该节目的主持人蒙提·霍尔(Monty Hall)。
这个游戏的玩法是:参赛者会看见三扇关闭的门,其中一扇门后面有一辆汽车,选中后面有车的那扇门就可以赢得该汽车,而另外两扇门后面则各藏有一只山羊。当参赛者选定了一扇门,但未去开启它的时候,节目主持人会开启剩下两扇门中的一扇,露出其中一只山羊。主持人其后会问参赛者要不要更换其初始的选择,选另一扇仍然关上的门。
那么问题来了,参赛者到底要不要更换其初始的选择呢?
解决这个问题需要用到贝叶斯定理:
让我们选一个特定的例子来看看:假设三扇门分别为Door A,Door B,Door C,并且参赛者初始选定了Door A,然后主持人展示了Door B。那么参赛者是坚持选择Door A还是更换成Door C呢?这就要根据Door A和Door C哪个门后汽车出现的概率较大决定了。
也就是说,我们需要解决P(Door A=car|Door A is selected, Door B is revealed)和P(Door C=car|Door A is selected, Door B is revealed)哪个大的问题。


首先,每个门后有车的概率都是1/3:
其次,如果Door A门后有汽车,那么Door A被选择的几率是1/3,假设初始选择了Door A,那么Door B被主持人打开的几率是1/2:
再次,普通情况下,Door A被选择的几率是1/3,Door B被主持人打开的几率是1/2(因为已经有一扇门被选择了,选择的门不能被打开):
同理,如果Door C门后有汽车,那么Door A被选择的几率是1/3,假设初始选择了Door A,那么Door B被主持人打开的几率是1:
因此,我们可以看到,P(Door C=car|Door A is selected, Door B is revealed)是P(Door A=car|Door A is selected, Door B is revealed)的两倍。也就是说,更换初始的选择将会使我们的获胜几率提高2倍!
可以用probability tree来帮助理解一下:

如果对上面的计算公式还有疑问,那么让我们用计算机来模拟一下:
from random import randint
from random import choice N = 1000 def simulate(N):
m=0 #设置不更换初始选择赢得汽车的次数
n=0 #设置更换初始选择赢得汽车的次数
for i in range(N): #模拟1000次游戏
win=randint(1,3) #设置藏有汽车的门,在1-3之间随机选出
bet1=randint(1,3) #设置初始选择的门,在1-3之间随机选出
remain=[i for i in range(1,4) if i!=win and i!=bet1] #剩余可选的门(除去初始选择的门和藏有汽车的门)
monty_reveal=choice(remain) #monty会在剩余可选的门中选择一扇门打开
bet2=6-bet1-monty_reveal #bet2表示更换初始选择(用6减是因为三扇门加起来等于6)
if bet1==win: #如果初始选择和藏有汽车的门吻合,那么初始选择的获胜次数+1
m+=1
if bet2==win: ##如果更换初始选择的bet2和藏有汽车的门吻合,那么bet2的获胜次数+1
n+=1
return n/m print(simulate(N))
2.0211480362537766
最后的结果: 更换初始选择获胜的次数差不多是不更换初始选择获胜次数的两倍。
三门问题是有些反直觉的,我们可以这样来理解:当参赛者选择Door A时,他的获胜概率是1/3,当主持人展示了Door B门后没有汽车以后,这个信息并没有给参赛者的初始选择带来任何有用的信息 ,选择Door A获胜的概率仍然是1/3,但是鉴于选择Door B获胜的概率降为了0,因此选择Door C获胜的概率变为1-1/3,也就是2/3。
参考:https://classroom.udacity.com/courses/st101/lessons/48744119/concepts/484806120923
用贝叶斯定理解决三门问题并用Python进行模拟(Bayes' Rule Monty Hall Problem Simulation Python)的更多相关文章
- 羊和汽车问题(或s三门问题(Monty Hall problem)亦称为蒙提霍尔问题)
三门问题(Monty Hall problem)亦称为蒙提霍尔问题.蒙特霍问题或蒙提霍尔悖论,大致出自美国的电视游戏节目Let's Make a Deal.问题名字来自该节目的主持人蒙提·霍尔(Mon ...
- Monty Hall Problem (三门问题)
最近有点忙,没怎么写程序...今天突然想起以前看到过的一个问题-三门问题,十分想用程序来模拟一下,于是实在忍不住了就模拟了这个游戏的实验,通过写程序更加加深了我对这个问题的理解,期间也查找了各种相关资 ...
- Monty 大厅问题(Monty Hall Problem)也称作三门问题,出自美国大型游戏节目 Let's Make a Deal。
Monty 大厅的问题陈述十分简单,但是它的答案看上去却是有悖常理.该问题不仅引起过很多争议,也经常出现在各种考试题中. Monty 大厅的游戏规则是这样的,如果你来参加这个节目,那么 (1)Mont ...
- Monty Hall 问题与贝叶斯定理的理解
三门问题(Monty Hall problem),是一个源自博弈论的数学游戏问题,大致出自美国的电视游戏节目Let's Make a Deal.问题的名字来自该节目的主持人蒙提·霍尔(Monty H ...
- Python科学计算(一)环境简介——Anaconda Python
Anaconda Python 是 Python 科学技术包的合集,功能和 Python(x,y) 类似.它是新起之秀,已更新多次了.包管理使用 conda,GUI基于 PySide,所有的包基本上都 ...
- 【Python五篇慢慢弹】快速上手学python
快速上手学python 作者:白宁超 2016年10月4日19:59:39 摘要:python语言俨然不算新技术,七八年前甚至更早已有很多人研习,只是没有现在流行罢了.之所以当下如此盛行,我想肯定是多 ...
- 【Python千问 2】Python核心编程(第二版)-- 欢迎来到Python世界
1.1 什么是Python 继承了传统编译语言的强大性和通用性,同时也借鉴了简单脚本和解释语言的易用性. 1.2 起源 来源于某个项目,那些程序员利用手边现有的工具辛苦工作着,他们设想并开发了更好的解 ...
- 用python实现模拟登录人人网
用python实现模拟登录人人网 字数4068 阅读1762 评论19 喜欢46 我决定从头说起.懂的人可以快速略过前面理论看最后几张图. web基础知识 从OSI参考模型(从低到高:物理层,数据链路 ...
- Python Web-第三周-Networks and Sockets(Using Python to Access Web Data)
1.Networked Programs 1.Internet 我们现在学习Internet部分,即平时我们浏览器做的事情,之后再学习客服端这部分 2.TCP 传输控制协议 3.Socket HTTP ...
随机推荐
- 朱晔的互联网架构实践心得S1E5:不断耕耘的基础中间件
朱晔的互联网架构实践心得S1E5:不断耕耘的基础中间件 [下载本文PDF进行阅读] 一般而言中间件和框架的区别是,中间件是独立运行的用于处理某项专门业务的CS程序,会有配套的客户端和服务端,框架虽然也 ...
- 关于NETCORE中使用特性Serializable找不到引用的解决方法
升级到netcore后,serializable特性不在命名空间System下了,需要nuget依赖包System.Runtime.Serialization.Formatters
- 第四次oo博客
论述测试与正确性论证的效果差异 单元测试利用测试者构造的测试用例来检查类或方法的正确性,一般来说所需要测试的用例是无穷多的,通过人为构造代表性的测试用例来尽量测试所有代码.测试的优点在于不易出错,只要 ...
- 基于 Token 的身份验证:JSON Web Token(附:Node.js 项目)
最近了解下基于 Token 的身份验证,跟大伙分享下.很多大型网站也都在用,比如 Facebook,Twitter,Google+,Github 等等,比起传统的身份验证方法,Token 扩展性更强, ...
- H5 67-清除浮动方式三
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...
- hibernate中实体与数据库中属性对应的类型
常用的字段及类型,在数据库中字段名称若与实体对应的属性字段名称相同,hibernate可以自动映射,在一些情况下hibernate可能报错这时候有的错误可以通过指定对应的类型避免.下面给出一些常用的 ...
- 砝码组合(dfs)
砝码组合 题目内容:用天平称重时,我们希望用尽可能少的砝码组合称出尽可能多的重量.如果只有5个砝码,重量分别是1,3,9,27,81.则它们可以组合称出1到121之间任意整数重量(砝码允许放在左右两 ...
- iOS- 利用AFNetworking(AFN) - 实现文件断点下载
https://www.cnblogs.com/qingche/p/3500746.html 1. 定义一个全局的AFHttpClient:包含有 1> baseURL 2> 请求 3&g ...
- iOS保持App真后台运行
https://www.jianshu.com/p/d466f2da0d33 在我看来,苹果系统与安卓系统最直观的区别就是后台处理方式了吧,安卓手机一旦开启了很多app放到后台,即使前台什么也不做,就 ...
- 面向对象设计的SOLID原则、迪米特法则
SPR(The Single Responsibility Principle):单一责任原则 OCP(The Open Closed Principle):开放封闭原则 LSP(The Liskov ...