三门问题(换门):

#include <iostream>

#include <cstdlib>

#include <ctime>

#define random(a,b) (rand() % (b-a+1))+ a

using namespace std;

int main()

{

srand((int)time(0));

int doors[3];

int mode;

int choose;

int result;

int success = 0;

for(int i = 0;i < 10000;++i) {//模拟一万次

mode = random(1,3);//3门问题的排列组合总共有三种情况

if(mode == 1) {//模式一是前两个门是羊,后一个门是汽车

doors[0] = 1;

doors[1] = 1;

doors[2] = 2;

choose = random(0,2);//玩家随机选择其中一个门

if(choose == 0) {//根据规则得到结果

result = 2;

}

else if(choose == 1) {

result = 2;

}

else {

result = 0;

}

if(doors[result] == 2) {//判断门后是否为汽车,如果为汽车,则统计量加1

++success;

}

}

else if(mode == 2) {//模式二为车、羊、羊

doors[0] = 2;

doors[1] = 1;

doors[2] = 1;

choose = random(0,2);

if(choose == 0) {

result = 1;

}

else if(choose == 1) {

result = 0;

}

else {

result = 0;

}

if(doors[result] == 2) {

++success;

}

}

else {//模式三为羊、车、羊

doors[0] = 1;

doors[1] = 2;

doors[2] = 1;

choose = random(0,2);

if(choose == 0) {

result = 1;

}

else if(choose == 1) {

result = 0;

}

else {

result = 1;

}

if(doors[result] == 2) {

++success;

}

}

}

cout << success << endl;//输出成功的总数

return 0;

}

三门问题(不换门):

#include <iostream>

#include <cstdlib>

#include <ctime>

#define random(a,b) (rand() % (b-a+1))+ a

using namespace std;

void game(int &success);//模拟做出选择后不更改的函数

int doors[3];

int main()

{

srand((int)time(0));

int mode;

int choose;

int result;

int success = 0;

for(int i = 0;i < 10000;++i) {//实验一万次

mode = random(1,3);//3门问题的排列组合总共有三种情况

if(mode == 1) {//模式一是前两个门是羊,后一个门是汽车

doors[0] = 1;

doors[1] = 1;

doors[2] = 2;

game(success);

}

else if(mode == 2) {//模式二为车、羊、羊

doors[0] = 2;

doors[1] = 1;

doors[2] = 1;

game(success);

}

else {//模式三为羊、车、羊

doors[0] = 1;

doors[1] = 2;

doors[2] = 1;

game(success);

}

}

cout << success << endl;//输出成功的总数

return 0;

}

void game(int &success) {

int result;

result = random(0,2);//随机选择一扇门

if(doors[result] == 2) {//如果选对了,统计量+1

++success;

}

}

结果:

换门后成功拿到汽车的频率10组数据如下,都接近三分之二(0.6666)

0.6692
0.6717
0.6697
0.669
0.6616
0.6712
0.6663
0.6693
0.6656
0.6686

不换门成功拿到汽车的频率10组数据如下,都接近三分之一(0.3333)

0.3409
0.3325
0.3399
0.3388
0.3354
0.3289
0.3337
0.3337
0.3343
0.3342

由此可见,三门问题的结论是正确的。

用C++验证三门问题的更多相关文章

  1. 三门问题模拟对比试验——附VB6和Python3源程序及EXE文件

    三门问题模拟对比试验 [直接跳转到文件下载] 前言 "三门问题"是一个很有意思的概率论问题,涉及贝叶斯公式,是人工智能领域的一个经典问题. 为了直观地研究这个问题,也为了测试一下P ...

  2. 用python验证蒙提霍尔问题

    最初看到这个问题是初中的时候买了一本有关数学谜题的书里面概率论的一张的课后拓展就是说到三门问题,当时作为一个扩展阅读看了一下,里面说到了一个世界智商最高的女人秒杀了美国一大群的数学高材生的精彩故事(比 ...

  3. 【探索】无形验证码 —— PoW 算力验证

    先来思考一个问题:如何写一个能消耗对方时间的程序? 消耗时间还不简单,休眠一下就可以了: Sleep(1000) 这确实消耗了时间,但并没有消耗 CPU.如果对方开了变速齿轮,这瞬间就能完成. 不过要 ...

  4. C# 中参数验证方式的演变

    一般在写方法的时候,第一步就是进行参数验证,这也体现了编码者的细心和缜密,但是在很多时候这个过程很枯燥和乏味,比如在拿到一个API设计文档的时候,通常会规定类型参数是否允许为空,如果是字符可能有长度限 ...

  5. Yii1.1的验证规则

    在Yii1.1的数据验证是由CValidator完成,在CValidator中提供了各种基本的验证规则 <?php public static $builtInValidators=array( ...

  6. 【WCF】使用“用户名/密码”验证的合理方法

    我不敢说俺的方法是最佳方案,反正这世界上很多东西都是变动的,正像老子所说的——“反(返)者,道之动”.以往看到有些文章中说,为每个客户端安装证书嫌麻烦,就直接采用把用户名和密码塞在SOAP头中发送,然 ...

  7. PHP验证用户登录例子-学习笔记

    1.基本流程: 2.UML类图: 3.PHP代码: 3.1 index.php <?php /** * Created by PhpStorm. * User: andy * Date: 16- ...

  8. 客户端的验证插件validator

    简单,智能,令人愉悦的表单验证~~~ 官方文档:http://www.niceue.com/validator/ <!DOCTYPE html> <html> <head ...

  9. ASP.NET MVC5+EF6+EasyUI 后台管理系统(66)-MVC WebApi 用户验证 (2)

    系列目录 前言: 回顾上一节,我们利用webapi简单的登录并进行了同域访问与跨域访问来获得Token,您可以跳转到上一节下载代码来一起动手. 继续上一篇的文章,我们接下来演示利用拿到的Token来访 ...

随机推荐

  1. (三)PL/SQL数据类型

    PL/SQL注释 程序注释是解释性说明,可以包括自己编写的,并帮助任何人阅读源代码的PL/SQL代码.所有的编程语言允许某种形式的注释. 在PL/SQL支持单行和多行注释.任何注释里面所有字符都会被P ...

  2. Windows 切换 working directory

    用函数 _chdir() 例如用计划任务启动,pwd 是 system32 使用相对路径的地方会出错. 在 main 函数刚启动的时候转换一下 working directory 可解.

  3. Windows API Index

    https://docs.microsoft.com/en-us/windows/desktop/apiindex/windows-api-list

  4. HashMap源码解析JDK8

    一.HashMap基础 1.1 HashMap的定义 我们先看一下HashMap的定义: public class HashMap<K,V> extends AbstractMap< ...

  5. Pig设计模式概要以及与SQL的设计模式的对比

    2019独角兽企业重金招聘Python工程师标准>>> 1概要模式 概要模式其实就是数据的全貌信息的获取,主要分为3种: 1.1数值概要 #HSQL SELECT MIN(num), ...

  6. 将不确定变成确定~LINQ DBML模型可以对应多个数据库吗

    答案是肯定的,一个DBML模型可以对应多个数据库,只要数据库中的表与模型中定义的表结构完成相同,就可以这个技术,我们可以用来开发一些通用的功能模块,如通过后台管理模块,我们将一些通用表进行抽象,如,对 ...

  7. 有关for循环的一些东西

    有的时候,不知道是因为学的有点浅显,还是脑袋有点懵,简单的循环语句都有点被绕糊涂了. 这种内外循环的,先是外循环一次,内循环全部,接着再外循环第二次,内循环全部,,,,,,,. 所以先是显示 0 4 ...

  8. 分享一批国内常用的tracker地址

    本期先分享一批国内能用地址,下一期我会出一期取代迅雷的下载的工具教程. udp://p4p.arenabg.com:1337/announce udp://tracker.tiny-vps.com:6 ...

  9. HDOJ 4699 Editor 对顶栈模拟

    Editor Time Limit: 3000/2000 MS (Java/Others) Memory Limit: 131072/131072 K (Java/Others) Total Subm ...

  10. 洛谷 P1816 忠诚 ST函数

    题目描述 老管家是一个聪明能干的人.他为财主工作了整整10年,财主为了让自已账目更加清楚.要求管家每天记k次账,由于管家聪明能干,因而管家总是让财主十分满意.但是由于一些人的挑拨,财主还是对管家产生了 ...