• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            隨筆 - 51, 文章 - 1, 評論 - 41, 引用 - 0
            數(shù)據(jù)加載中……

            倒數(shù)1、2的票數(shù)相同的概率

            我是歌手第4季第一集就出現(xiàn)了倒數(shù)1、2名票數(shù)相同的情況,使得原本應(yīng)該淘汰一名選手的賽制無法執(zhí)行。出現(xiàn)這種概率的情況有多大?下面是粗略模擬計算其概率的python代碼。雖然無法估計每個候選人的權(quán)重,但出現(xiàn)倒數(shù)1、2名票數(shù)相同的情況也有百分之幾,概率不小。

            """本程序測試在投票活動中,出現(xiàn)并列倒數(shù)第一的概率是多少"""

            import random

                   
            def onePoll(candidates):
                """候選人進行一次投票

                Parameters
                ----------
                candidates: [Integer]
                    候選人的權(quán)重,權(quán)重越大越可能被投票,len(candidates)是候選人數(shù)

                Returns
                -------
                choiced: Integer, [0, len(candidates))
                    被投票候選人的序號
                """
               
                t = sum(candidates)
                n = random.randint(0, t-1)
                for i in range(len(candidates)):
                    if (n >= candidates[i]):
                        n -= candidates[i]
                    else:
                        return i
                else:
                    assert False, "不應(yīng)該進入該分支"
               
            def generatePollResult(voters, candidates):
                """產(chǎn)生投票結(jié)果

                Parameters
                ----------
                voters: Integer
                    投票人數(shù)
                candidates: [Integer]
                    候選人的權(quán)重,權(quán)重越大越可能被投票,len(candidates)是候選人數(shù)
               
                Returns
                -------
                result: [Integer]*len(candidates)
                    每個人所得票數(shù)
                """


                result = [0]*len(candidates)
                for i in range(voters):
                    result[onePoll(candidates)] += 1
                return result


            def simulate(count, voters, candidates, judge):
                """模擬投票行為,統(tǒng)計滿足要求的投票結(jié)果的概率

                Parameters
                ----------
                count: Integer
                    模擬投票的次數(shù)
                voters: Integer
                    投票人數(shù)
                candidates: [Integer]
                    候選人的權(quán)重,權(quán)重越大越可能被投票,len(candidates)是候選人數(shù)
                judge: bool ([Integer]*len(candidates))
                    對投票結(jié)果是否符合要求的判斷

                Results
                -------
                prop: Float
                    所求投票結(jié)果的概率
                """

                satisfied = 0

                for i in range(count):
                    result = generatePollResult(voters, candidates)
                    if (judge(result)):
                        satisfied += 1

                return float(satisfied) / count
               
            if __name__ == "__main__":
               
                def isLast2Equal(result):
                    result.sort()
                    return result[0] == result[1]

                print(simulate(1000, 500, [110,120,130,140,150,160,170,180], isLast2Equal))

            posted on 2016-01-17 20:03 lemene 閱讀(208) 評論(0)  編輯 收藏 引用


            只有注冊用戶登錄后才能發(fā)表評論。
            網(wǎng)站導(dǎo)航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


            久久99久久无码毛片一区二区 | 久久久久无码中| 久久精品成人欧美大片| 人妻无码αv中文字幕久久琪琪布 人妻无码久久一区二区三区免费 人妻无码中文久久久久专区 | 日韩va亚洲va欧美va久久| 国产精品免费看久久久香蕉| 99久久99久久精品国产片果冻| 亚洲国产精品热久久| 久久久国产精华液| 精品一久久香蕉国产线看播放 | 国产精品久久99| 亚洲日本va午夜中文字幕久久| 91久久精品视频| 蜜臀av性久久久久蜜臀aⅴ麻豆| 亚洲国产成人精品久久久国产成人一区二区三区综 | 久久久久99精品成人片| 久久强奷乱码老熟女| 精品无码久久久久国产| 久久无码AV中文出轨人妻| 久久久精品国产sm调教网站| 久久久久久国产精品美女| 亚洲午夜精品久久久久久app| 亚洲精品美女久久777777| 久久久久国产精品嫩草影院| 久久91亚洲人成电影网站| 久久精品国产亚洲AV无码麻豆| 国产成人精品久久亚洲高清不卡 | 久久久久亚洲AV成人网人人软件| 亚洲精品视频久久久| 久久91精品综合国产首页| 国产成人精品久久一区二区三区| 国产69精品久久久久APP下载 | 成人免费网站久久久| 精品一区二区久久| 品成人欧美大片久久国产欧美| 久久精品人人做人人妻人人玩| 亚洲一区精品伊人久久伊人 | 精品国产一区二区三区久久蜜臀| 久久综合久久自在自线精品自| 国产精品久久久久免费a∨| 亚洲中文字幕无码久久综合网 |