QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 6341|回复: 0
打印 上一主题 下一主题

用python模拟三门悖论

[复制链接]
字体大小: 正常 放大

7

主题

9

听众

496

积分

升级  65.33%

  • TA的每日心情

    2015-11-11 09:17
  • 签到天数: 234 天

    [LV.7]常住居民III

    社区QQ达人

    群组2013年电工杯B题讨论群

    群组2014年网络挑战赛交流

    跳转到指定楼层
    1#
    发表于 2014-9-18 17:07 |只看该作者 |正序浏览
    |招呼Ta 关注Ta
    直觉的欺骗,三门悖论的模拟
    以下描述来自百度百科:
    0 X6 Y1 \' }$ v( Y2 i  z三门问题(Monty Hall problem)亦称为蒙提霍尔问题、蒙特霍问题或蒙提霍尔悖论,大致出自美国的电视游戏节目Let's Make a Deal。问题名字来自该节目的主持人蒙提·霍尔(Monty Hall)。参赛者会看见三扇关闭了的门,其中一扇的后面有一辆汽车,选中后面有车的那扇门可赢得该汽车,另外两扇门后面则各藏有一只山羊。当参赛者选定了一扇门,但未去开启它的时候,节目主持人开启剩下两扇门的其中一扇,露出其中一只山羊。主持人其后会问参赛者要不要换另一扇仍然关上的门。问题是:换另一扇门会否增加参赛者赢得汽车的机会率?如果严格按照上述的条件,即主持人清楚地知道,哪扇门后是羊,那么答案是会。换门的话,赢得汽车的机率是2/3。
    - v4 H3 M8 E- l- h0 Q0 U
    7 `( q: P) o0 o* D! |2 k$ W鄙人谈几句话:3 @1 I) O' x) p, h
    很多人都认为改变选择之后是二选一的情况,认为赢得汽车的概率是1/2,包括伟大的数学家鄂尔多斯都这样认为。但是我们要用事实来证明,如果真实做这个实验,会消耗太多资源,下面由鄙人用计算机编程来模拟这个情形。源码公开,如果有大神觉得不妥,欢迎指正。: r. M" Y% W7 E( Y/ @
    0 p8 H6 X; K6 X6 F8 k9 @1 {4 n
    以下是鄙人的python模拟程序:
    5 B6 E$ }1 `7 r       #Author : Naupio
    / B' T: [, X0 fimport random as rd
    , ^+ e2 ~7 `/ D5 M% k& D# V2 cchange = True
    : X' |( G5 S: t8 ddef moni(times=10000):
    . c3 J, P6 W' B7 |! b7 u1 X, R/ N    counts = 0.0
    / ~+ t8 H& g% o' C% q- q4 a9 V    for i  in range(times):
    : v' U# P& g1 K1 q3 M" E        rightaim = int(rd.random()*3)  #汽车所在的门5 ~5 e3 n& t7 V8 D
            guss = int(rd.random()*3)      #第一次猜的门
    5 w/ n" |2 O( i  M8 d        aim=[0,1,2]                    #初始化三个门. l* ~/ O1 m9 o9 F4 m$ Y/ {6 M3 j
                   
    ( }# h! G% F; W( m/ D        #找出要主持人打开的门 % y+ k6 R, X. t
            for j in aim:
    0 p* ]( k4 s' X: L            if (j!=guss and j!=rightaim):" `& t! N3 V8 d5 ~% F' Y4 Y
                    openaim = j! s( L& g2 j7 P' B$ j, A
                    break
    % i% S! Z0 S' v4 X% k  + T( f' c/ h0 D
            #找出另一个门
    9 U& o8 z! V. l. Q+ l        for j in aim:; x6 K1 s! e, ?
                if (j!=guss and j!=openaim):0 ^2 M3 S( G# s$ ]; j
                    otheraim =j% {( o4 Y/ T6 a
                    break8 y0 I6 G& R- F7 t2 K$ ~9 B
    # h& t6 a2 S( u- s( ~

    - r$ _' c3 }3 s9 }# E3 `+ q        #改变选择
    2 C, K; U$ o. v' o        if change:
    # T% m' `9 P2 A) m4 e9 W            guss = otheraim! j5 j1 l9 u8 M2 e
             
    * }' k. {2 K; G1 N$ d        #改变选择之后猜中汽车的次数统计
    4 j' ^. K+ y( ]8 r) u        if guss==rightaim:0 @+ M8 `1 t/ `) Q! z
                counts+=1
    ! I: ~+ q4 w% q+ u, V1 s        
    7 A( L7 J- B! e( `" ?5 B            #返回改变选择之后猜中汽车的概率 3 A! w5 n! h9 b& P5 H- I; g! f9 y4 A) o
        return counts/times
    4 o; n6 l8 `9 Z2 T9 a; ?# fprint "改变选择之后的模拟一千次结果是:",moni(1000)
    9 ~2 o* C( @, }  c- W- i7 jprint "改变选择之后的模拟一万次结果是:",moni(10000)
    ' ]8 t" @* I- Nprint "改变选择之后的模拟十万次结果是:",moni(100000)
      a( D  S! O6 Zprint "改变选择之后的模拟一百万次结果是:",moni(1000000)7 x) u% H$ O9 z5 g3 s5 \
    print "改变选择之后的模拟一千万次结果是:",moni(10000000)   l; q) |# a7 K# e  C' N' m

    0 t) l* w  R7 [9 c2 Z, h& G以下是模拟效果截图: % @; P/ z5 N0 R# m1 W3 n! n
      j% |: q. b6 r
    , U! s) I: r+ {6 Z
    鄙人最后说几句:
    , b7 _. j$ Q' ?* e8 W' y 从模拟的结果上来看还算是成功的,随着模拟的次数越来越多,结果越来越接近2/3,本来想打算再提高模拟次数的,但由于我的本本比较渣,会卡爆,所以只模拟到一千万次。6 f( ?) t/ {: h  y' N2 B" S9 I
    @百年孤独 @数学中国—罂粟 @madio
    1 Y* U$ p9 h2 M+ C3 e* U& [ps:不排除有错误,欢迎指正,欢迎交流,转载请注明出处,版权所有。

    " T. G$ ~& Q, W' a3 N/ n& v7 f1 I. r1 L. D1 o# Q# G  H: H1 y( V
    6 E: `4 ^) {$ m, ?+ V
    / F; V( ^1 W, H; g  |/ O: L/ ^2 A) t
    zan
    转播转播0 分享淘帖0 分享分享0 收藏收藏0 支持支持0 反对反对0 微信微信
    您需要登录后才可以回帖 登录 | 注册地址

    qq
    收缩
    • 电话咨询

    • 04714969085
    fastpost

    关于我们| 联系我们| 诚征英才| 对外合作| 产品服务| QQ

    手机版|Archiver| |繁體中文 手机客户端  

    蒙公网安备 15010502000194号

    Powered by Discuz! X2.5   © 2001-2013 数学建模网-数学中国 ( 蒙ICP备14002410号-3 蒙BBS备-0002号 )     论坛法律顾问:王兆丰

    GMT+8, 2026-4-15 12:37 , Processed in 0.268840 second(s), 50 queries .

    回顶部