三门问题(换门):

#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. CG-CTF(3)

    CG-CTF https://cgctf.nuptsast.com/challenges#Web 续上~ 第十四题:GBK Injection 是一道注入题: 分析:题目提示了GBK,GBK是一种多字 ...

  2. Python3 注释和运算符

    Python3 注释 确保对模块, 函数, 方法和行内注释使用正确的风格 Python中的注释有单行注释和多行注释: Python中单行注释以 # 开头,例如:: # 这是一个注释 print(&qu ...

  3. 防cc攻击利器之Httpgrard

    一.httpgrard介绍 HttpGuard是基于openresty,以lua脚本语言开发的防cc攻击软件.而openresty是集成了高性能web服务器Nginx,以及一系列的Nginx模块,这其 ...

  4. QQ靓号资料空白且空间开通教程

    QQ靓号资料空白且空间开通教程 首先你需要两个QQ号第一个是普通QQ号第二个是去这个官方网站注册一个QQ免费靓号https://ssl.zc.qq.com/v3/index-chs.html?type ...

  5. MySQL根据业务场景归纳常用SQL语句

    素材表数据:user[{"id":1,"name":"x"},{"id":2,"name":&quo ...

  6. Vue Cli 3 打包上线 部署到Apache Tomcat服务器

    使用 npm run build 打包项目 在根目录中有一个dist文件夹 我使用的服务器是 Apache  Tomcat 把项目放进tomcat /webapps 中 启动服务器 <mac O ...

  7. 剑指offer---05---用栈实现队列

    题意 给了两个栈去实现队列   分析 两个栈如下情况       1       2 4    3 这个时候就不能够把4插入到第二个弹出栈了否则弹出顺序出错. 所以这个时候就应该等第二个栈空了的时候再 ...

  8. JS基础入门篇(十)— 数组方法

    1.join 作用: 将数组通过指定字符拼接成字符串.语法: string arr.join([separator = ',']);参数: separator可选,如果省略的话,默认为一个逗号.如果 ...

  9. cookie ,session 和localStorage的区别详解

    2019独角兽企业重金招聘Python工程师标准>>> cookie ,session 和localStorage的区别详解 博客分类: js 当你在浏览网站的时候,WEB 服务器会 ...

  10. 图论--割点--Tarjan模板

    #include <iostream> #include <algorithm> #include <cstdio> #include <cstring> ...