蒙提霍尔的c语言程序,图解|什么是蒙提霍尔问题

2023-10-18 05:20

本文主要是介绍蒙提霍尔的c语言程序,图解|什么是蒙提霍尔问题,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

原标题:图解|什么是蒙提霍尔问题

来源 | 后端技术指南针

如若转载请联系原公众号

1.写在前面

前几天和同事聊了个问题,觉得还蛮有趣,决定和大家分享一下。

Oh My God! 搞它搞它!

7c9ef4d9b04dee139eea172e82073c9e.png

2. 题目描述

我们的热心读者小明被选中参加一个抽奖游戏,游戏规则是这样的:

小明面前有ABC三扇相同的门,小明和观众无法知道ABC三扇门背后有什么。

ee044d2bf2590351b4b49dde1f031baa.png

ABC三扇门中只有一扇门背后有一辆汽车,其他两扇门背后都是一瓶矿泉水。

c5c6a4ff298890987c0ebb7b5a798344.png

小明需要在3扇门中选中一个并且不开启,接下来主持人从另外两扇门中选中一扇门并且开启。

c43a99cb62ba229937bde3a73bb9edac.png

小明选中了A门,主持人选中了B门,并且开启B门后是矿泉水。

a8775138ee27c773c1ebf67a512a6e64.png

这时主持人问小明,明哥你要不要从A门换选C门呢?

2ad13974781dd0acde7ed10850c3b302.png

大家都替小明思考一下,别瞎蒙,要有理有据,能不能提到这辆法拉利就在此一搏了!

3. 蒙提·霍尔问题

相信很多老铁知道这个问题,这就是有名的 蒙提霍尔问题(Monty Hall Problem),也称三门问题。

这是一个源自博弈论的数学游戏问题,出自美国的电视游戏节目Let's Make a Deal。

这里面有个非常重要的线索:主持人知道哪扇门后有汽车且会选中背后有水的那扇门,这也是争议的所在,相当于个隐含条件吧。

在维基百科对于Monty Hall问题的描述中,门的背后是山羊和汽车,本文替换成了矿泉水,但是数学原理是一样的,大白是想尽量排除干扰,避免读者钻牛角尖。

面对这个问题, 很多人认为换或者不换选中汽车的概率都是1/2,还有一部分人认为应该换了之后的概率更大是2/3。

319dd309461279b7990f0746533a91c1.png

4. 朴素分析

换或者不换,是个问题。

e0906794028314bcc6dda4b5525ea014.png

4.1 不换的1/2派

由于主持人已经帮小明淘汰了一个选项,剩下的就只有两个了。

很直观地感觉一下,A门和C门背后有汽车的概率都是1/2,这个结论也是符合大部分人直观第一感觉的答案,这也是大白的第一答案...害

ecb691e789231a06993a66aef17f9aa5.png

但是还有句话,真理往往掌握在少数人手中,所以这个直观答案并不一定正确呀!

4.2 调换的2/3派

调换派认为不换的话有车的概率就是最初的1/3,由于B和C总体的概率为2/3,且已经被排除了B,那么修改选择后,选C有车的概率就是2/3。

详细分析一下这几种可能:

A扇门背后有车,如果调换到C,那么一定没有车,这种场景的概率是1/3。

A扇门背后无车,如果调换到C,那么一定有车,这种场景的概率是2/3。

ab2329d25b801309d92da42faeadcba6.png

确实非常有道理,用一个低概率成功去换取一个高概率成功,太机智了!

4.3 分歧所在

在主持人没有开启B门之前,我们对选择A后有汽车的概率是1/3是毫无争议的。

但是当主持人开启B门之后,就出现了分歧, 那么不由得去想B门的开启是否影响了之前的选择A呢?

7fd01309f1a88512135ce92674267f63.png

5. 数学分析

没有数学分析,大家貌似说的都有道理, 所以必须亮出大神器-概率分析。

这几个概率论的术语,大家都是学过的,所以不必有什么数学恐惧。

1680d46323d594e57bfa6f33f3eb1a9d.png

5.1 独立事件的概率和条件概率

独立事件概率

我们设定事件a的概率为P(a),事件b的概率是P(b),且事件a和事件b是相互独立的。

则事件a和事件b同时发生的概率,满足如下公式:

P(ab)=P(ba)=P(a)P(b)

条件概率

条件概率是在某种条件下,某个事件发生的概率,展示了事件之间的内在联系和影响。

我们来看两种条件概率的简单表述。

事件a发生之后,事件b发生的概率,可以记做P(b|a),此时满足公式:

P(b|a)=P(ab)/P(a)

等价于 P(ab)=P(b|a)P(a)

事件b发生之后,事件a发生的概率,可以记做P(a|b),此时满足公式:

P(a|b)=P(ab)/P(b)

等价于 P(ab)=P(a|b)P(b)

综合这两种条件事件,可以得到公式:

P(ab)=P(b|a)P(a)=P(a|b)P(b)5.2 贝叶斯公式

我们综合计算得到一个公式:

P(b|a)P(a)=P(a|b)P(b)

这个公式做一个变形可以得到:

P(a|b)=P(b|a)P(a)/P(b)

没错,这就是大名鼎鼎的 贝叶斯公式。

5.3 先验概率和后验概率

在贝叶斯公式中,还隐含着一些术语,来看下百度百科对于其中的定义:

P(A)是A的先验概率或边缘概率,它不考虑任何B方面的因素。

P(A|B)是B发生后A的条件概率,由于得自B的取值被称作A的后验概率。

P(B|A)是A发生后B的条件概率,由于得自A的取值被称作B的后验概率。

P(B)是B的先验概率或边缘概率,称作标准化常量。

贝叶斯公式的意义非常重大,它揭示了条件事件概率的内在联系,某些样本信息的出现对先验概率的影响。

贝叶斯公式为我们利用搜集到的信息对原有判断进行修正提供了有效手段。

在很多领域都有非常深远的影响,正好用在我们今天的蒙提霍尔问题上,继续来分析。

6. 贝叶斯公式和蒙提霍尔问题

前面我们提到了, 症结在于主持人选择B门并开启后无车,这个事件对于已作出选择的参与者来说是否有影响呢?

后验概率是否产生了影响,我们来推导一下:

设定A、B、C门后有汽车分别记为事件a、b、c,则P(a)=P(b)=P(c)=1/3。

设定参与者选择了A门,由于主持人默认需要选择没有汽车的门,因此参与者的选择影响了主持人的选择。

设定主持人选择了B门且没有汽车,记为事件d,则P(d|a)=1/2,P(d|b)=0,P(d|c)=1。

在主持人选择B门无汽车后,参与者选择A门有车的概率为P(a|d),即事件d发生后事件a的概率,由贝叶斯公式得:

P(a|d)=P(d|a)P(a)/P(d)

通过前面的分析,我们只需要求P(d|a)、P(a)、P(d)三个元素即可。

P(d|a)表示A门有汽车的情况下,主持人选择B门的概率,其为1/2;

P(a)表示A门有汽车的概率,其为1/3;

P(d)可以从全概率公式求得,其为1/2:

P(d)=P(d|a)P(a)+P(d|b)P(b)+P(d|c)P(c)

P(d)=1/2*1/3+0*1/3+1*1/3=1/2

综上得到:P(a|d)=1/2*1/3*2=1/3

在主持人选择B门开启后无汽车的情况下,参与者选A门有汽车的概率P(a|d)=1/3,因此后验概率并没有发生变化,并不是直观的1/2,而仍然是1/3。

因此如果做调换,那么相当于参与者选择了C门,计算过程类似,概率为2/3:

P(c|d)=P(d|c)P(c)/P(d)

7.蒙提霍尔问题的思考

想这个问题的时候,总觉得有漏洞,或者说必须在某些条条框框才能正常推演。

比如说假如主持人并不知道哪扇门后有汽车,他也是随机选择的。

比如说数据规模不一样,9扇门,主持人帮你否定7个,显然要换,正是因为数据规模很小才带来了和直觉相悖的感觉。

最后用Horst Hohberger的一段话概括,蒙提霍尔问题:

If you change, you win when your original choice was wrong;

if you don't change, you win when your original choice was right.

如果你想赢得汽车,两种情况的概率:

不换情况下必须是最初选择是对的才会赢取法拉利,概率1/3

调换情况下必须是最初选择是错的才会赢取法拉利,概率2/3

网上有一些大佬,写代码模拟这个独立重复实验,得到的结果也是一样的。

今天先到这里,感谢各位老铁的倾情安排!

点击图片参与活动免费包邮送书

● 图解+代码 | 你被限流了吗?返回搜狐,查看更多

责任编辑:

这篇关于蒙提霍尔的c语言程序,图解|什么是蒙提霍尔问题的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/230460

相关文章

C语言中%zu的用法解读

《C语言中%zu的用法解读》size_t是无符号整数类型,用于表示对象大小或内存操作结果,%zu是C99标准中专为size_t设计的printf占位符,避免因类型不匹配导致错误,使用%u或%d可能引发... 目录size_t 类型与 %zu 占位符%zu 的用途替代占位符的风险兼容性说明其他相关占位符验证示

解决pandas无法读取csv文件数据的问题

《解决pandas无法读取csv文件数据的问题》本文讲述作者用Pandas读取CSV文件时因参数设置不当导致数据错位,通过调整delimiter和on_bad_lines参数最终解决问题,并强调正确参... 目录一、前言二、问题复现1. 问题2. 通过 on_bad_lines=‘warn’ 跳过异常数据3

解决RocketMQ的幂等性问题

《解决RocketMQ的幂等性问题》重复消费因调用链路长、消息发送超时或消费者故障导致,通过生产者消息查询、Redis缓存及消费者唯一主键可以确保幂等性,避免重复处理,本文主要介绍了解决RocketM... 目录造成重复消费的原因解决方法生产者端消费者端代码实现造成重复消费的原因当系统的调用链路比较长的时

深度解析Nginx日志分析与499状态码问题解决

《深度解析Nginx日志分析与499状态码问题解决》在Web服务器运维和性能优化过程中,Nginx日志是排查问题的重要依据,本文将围绕Nginx日志分析、499状态码的成因、排查方法及解决方案展开讨论... 目录前言1. Nginx日志基础1.1 Nginx日志存放位置1.2 Nginx日志格式2. 499

kkFileView启动报错:报错2003端口占用的问题及解决

《kkFileView启动报错:报错2003端口占用的问题及解决》kkFileView启动报错因office组件2003端口未关闭,解决:查杀占用端口的进程,终止Java进程,使用shutdown.s... 目录原因解决总结kkFileViewjavascript启动报错启动office组件失败,请检查of

C语言进阶(预处理命令详解)

《C语言进阶(预处理命令详解)》文章讲解了宏定义规范、头文件包含方式及条件编译应用,强调带参宏需加括号避免计算错误,头文件应声明函数原型以便主函数调用,条件编译通过宏定义控制代码编译,适用于测试与模块... 目录1.宏定义1.1不带参宏1.2带参宏2.头文件的包含2.1头文件中的内容2.2工程结构3.条件编

Go语言并发之通知退出机制的实现

《Go语言并发之通知退出机制的实现》本文主要介绍了Go语言并发之通知退出机制的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧... 目录1、通知退出机制1.1 进程/main函数退出1.2 通过channel退出1.3 通过cont

SpringBoot 异常处理/自定义格式校验的问题实例详解

《SpringBoot异常处理/自定义格式校验的问题实例详解》文章探讨SpringBoot中自定义注解校验问题,区分参数级与类级约束触发的异常类型,建议通过@RestControllerAdvice... 目录1. 问题简要描述2. 异常触发1) 参数级别约束2) 类级别约束3. 异常处理1) 字段级别约束

Go语言编译环境设置教程

《Go语言编译环境设置教程》Go语言支持高并发(goroutine)、自动垃圾回收,编译为跨平台二进制文件,云原生兼容且社区活跃,开发便捷,内置测试与vet工具辅助检测错误,依赖模块化管理,提升开发效... 目录Go语言优势下载 Go  配置编译环境配置 GOPROXYIDE 设置(VS Code)一些基本

Python错误AttributeError: 'NoneType' object has no attribute问题的彻底解决方法

《Python错误AttributeError:NoneTypeobjecthasnoattribute问题的彻底解决方法》在Python项目开发和调试过程中,经常会碰到这样一个异常信息... 目录问题背景与概述错误解读:AttributeError: 'NoneType' object has no at