精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

我們在程序員節組織了一場游戲,竟還用Python去驗證其公平性?

開發 后端
程序員節,公司舉辦了一個抽獎活動,采用的方式是擲六次骰子,組成一個六位數,再對群里的人數取模,計算的結果就是中獎的人的編號。但這種方式公平嗎?讓我們用Python來驗證下。

[[432910]]

本文轉載自微信公眾號「數據和云」,作者楊豹。轉載本文請聯系數據和云公眾號。

程序員節,公司舉辦了一個抽獎活動,采用的方式是擲六次骰子,組成一個六位數,再對群里的人數取模,計算的結果就是中獎的人的編號。但這種方式公平嗎?讓我們用Python來驗證下。

一、驗證

擲六次骰子,那么這個值就是在111111~666666之間,有6的6次方(即46656)個隨機數。

  1. nums = [x for x in range(111111, 666667) if not set(str(x)).intersection('0789')] 
  2. print(len(nums))  # 46656 

假設群里有134人,用上面46656個數分別對134取模,看最后的結果分布。

  1. total_person = 134 
  2. nums_mod = list(map(lambda x: x % total_person, nums)) 
  3. for i in range(0, total_person): 
  4.     print('編號: {}, 中獎次數: {}'.format(i, nums_mod.count(i))) 
  5. 編號: 0, 中獎次數: 349 
  6. 編號: 1, 中獎次數: 348 
  7. 編號: 2, 中獎次數: 348 
  8. 編號: 3, 中獎次數: 350 
  9. 編號: 4, 中獎次數: 350 
  10. 編號: 5, 中獎次數: 346 
  11. 編號: 6, 中獎次數: 346 
  12. 編號: 7, 中獎次數: 342 
  13. 編號: 8, 中獎次數: 342 
  14. 編號: 9, 中獎次數: 349 
  15. 編號: 10, 中獎次數: 349 
  16. .... 

看數字不直觀,我們把它轉化為圖片:

  1. import matplotlib.pyplot as plt 
  2. x = range(0, total_person) 
  3. y = [nums_mod.count(i) for i in x] 
  4. fig, ax = plt.subplots() 
  5. ax.plot(x, y) 
  6. ax.set(xlabel='person no.', ylabel='prize counts', title='{} person'.format(total_person)) 
  7. ax.set_xlim(0, total_person) 
  8. ax.set_ylim(0, 1000) 
  9. plt.show() 

可以看到對于群里有134個人,還是很公平的,假設群里又加了一個人,變成135人,那么每人的中獎幾率是多少呢?

將total_person改成135,再運行下程序:

  1. 編號: 0, 中獎次數: 280 
  2. 編號: 1, 中獎次數: 577 
  3. 編號: 2, 中獎次數: 297 
  4. 編號: 3, 中獎次數: 297 
  5. 編號: 4, 中獎次數: 297 
  6. 編號: 5, 中獎次數: 297 
  7. 編號: 6, 中獎次數: 581 
  8. 編號: 7, 中獎次數: 284 
  9. 編號: 8, 中獎次數: 284 
  10. 編號: 9, 中獎次數: 284 
  11. ... 

這時候就不公平了,中獎次數最少的277,最大的有584,而且中獎次數多的都是對應的編號尾數為1和6。為什么會出現這種現象呢?將前面的代碼改造下。

  1. total_person = 135 
  2. from collections import defaultdict 
  3. for i in range(0, total_person): 
  4.     nums_filter = list(filter(lambda x: x % total_person == i, nums)) 
  5.     num_last_number = defaultdict(int
  6.     for j in nums_filter: 
  7.         num_last_number[j % 10] += 1 
  8.     print('編號: {}, 中獎次數: {}, 骰子尾數統計: {}'.format(i, len(nums_filter), num_last_number)) 

可以看到當編號尾數是1或6時,對應的骰子尾數是1或6,而其它的編號對應的骰子尾數都只有一個數字,即0-5,2-2,7-2等。所以才會出現編號尾數為1和6的中獎次數接近其它編號的兩倍。

  1. 編號: 0, 中獎次數: 280, 骰子尾數統計: defaultdict(<class 'int'>, {5: 280}) 
  2. 編號: 1, 中獎次數: 577, 骰子尾數統計: defaultdict(<class 'int'>, {1: 297, 6: 280}) 
  3. 編號: 2, 中獎次數: 297, 骰子尾數統計: defaultdict(<class 'int'>, {2: 297}) 
  4. 編號: 3, 中獎次數: 297, 骰子尾數統計: defaultdict(<class 'int'>, {3: 297}) 
  5. 編號: 4, 中獎次數: 297, 骰子尾數統計: defaultdict(<class 'int'>, {4: 297}) 
  6. 編號: 5, 中獎次數: 297, 骰子尾數統計: defaultdict(<class 'int'>, {5: 297}) 
  7. 編號: 6, 中獎次數: 581, 骰子尾數統計: defaultdict(<class 'int'>, {1: 284, 6: 297}) 
  8. 編號: 7, 中獎次數: 284, 骰子尾數統計: defaultdict(<class 'int'>, {2: 284}) 
  9. 編號: 8, 中獎次數: 284, 骰子尾數統計: defaultdict(<class 'int'>, {3: 284}) 
  10. 編號: 9, 中獎次數: 284, 骰子尾數統計: defaultdict(<class 'int'>, {4: 284}) 
  11. ... 

二、破局

前面概述提到的辦法對于人數是135就不太公平了呀,怎么保證公平呢。公平就是每個人獲獎的幾率必須是一樣。這就要求骰子擲出來的數字要足夠隨機而且連續。由于單個骰子只有6個不同值,為了讓它連續,我們設置骰子的1-6,分別對應數字0-5,而且采用6進制。

比如骰子擲出來的數分別是1、3、4、6、2、5,那么對應的數字就是0、2、3、5、1、4,換算成十進制則為int(‘023514’, 6) = 3430,代碼就可以換成如下:

  1. nums = [int(str(x), 6) for x in range(0, 555556) if not set(str(x)).intersection('6789')] 
  2. print(len(nums)) 
  3.  
  4. total_person = 135 
  5. nums_mod = list(map(lambda x: x % total_person, nums)) 
  6. for i in range(0, total_person): 
  7.     print('編號: {}, 中獎次數: {}'.format(i, nums_mod.count(i))) 
  8.  
  9. import matplotlib.pyplot as plt 
  10. x = range(0, total_person) 
  11. y = [nums_mod.count(i) for i in x] 
  12. fig, ax = plt.subplots() 
  13. ax.plot(x, y) 
  14. ax.set(xlabel='person no.', ylabel='prize counts', title='{} person'.format(total_person)) 
  15. ax.set_xlim(0, total_person) 
  16. ax.set_ylim(0, 1000) 
  17. plt.show() 

這才是!

三、總結

本文由公司的一個小游戲有感而發,主要是想介紹下Python中的map和filter函數,以及matplotlib畫圖模塊。最后附上一個小游戲代碼。

  1. from collections import defaultdict 
  2.  
  3. class Prize: 
  4.     DICE_MAX_DIGIT = 5  # 骰子的最大點數,骰子的1-6,對應數字0-5 
  5.  
  6.     def __init__(self, person_nums): 
  7.         # 活動人數 
  8.         self.person_nums = person_nums 
  9.         # 中獎幾率差異,這里控制到1% 
  10.         self.percent_diff = 0.01 
  11.  
  12.     def _need_throw_times(self): 
  13.         ""
  14.         確定需要投擲的次數 
  15.         ""
  16.         self.throw_time = 1  # 初始投擲次數 
  17.         while True
  18.             max_number = int(str(self.DICE_MAX_DIGIT) * self.throw_time)  # 投擲出來的最大值 
  19.             nums = [int(str(x), 6) for x in range(0, max_number+1) if not set(str(x)).intersection('6789')]  # 投擲出來所有可能的十進制值 
  20.             if max(nums) + 1 < self.person_nums: 
  21.                 # 如果投擲出來的最大值比總人數少,直接增加投擲次數 
  22.                 self.throw_time += 1 
  23.                 continue 
  24.             prize_dict = defaultdict(int
  25.             for i in nums: 
  26.                 prize_dict[i % self.person_nums] += 1 
  27.             percent_diff = (max(prize_dict.values()) - min(prize_dict.values()))/max(prize_dict.values()) 
  28.             if percent_diff < self.percent_diff: 
  29.                 return self.throw_time 
  30.             self.throw_time += 1 
  31.  
  32.     def say(self): 
  33.         self._need_throw_times() 
  34.         print('本次活動人數為{},請依次投擲{}次骰子'.format(self.person_nums, self.throw_time)) 
  35.         number_str = '' 
  36.         for i in range(self.throw_time): 
  37.             point = input('第{}次骰子的點數為: '.format(i + 1)) 
  38.             if point not in ('1''2''3''4''5''6'): 
  39.                 raise Exception('點數超出范圍'
  40.             number_str += str(int(point) - 1) 
  41.         int_number_str = int(number_str, 6) 
  42.         print('恭喜{}號中獎!'.format(int_number_str % self.person_nums)) 
  43.  
  44. if __name__ == '__main__'
  45.     x = input('請輸入活動的人數: '
  46.     Prize(int(x)).say() 

關于作者

楊豹,國泰君安DBA,愛好Oracle、MySQL,Python。

 

責任編輯:武曉燕 來源: 數據和云
相關推薦

2021-09-13 15:38:26

戴爾

2013-04-24 09:32:24

程序員創業

2022-09-29 08:00:00

人工智能運輸公平性

2015-05-25 09:33:16

程序員Bug

2015-08-25 08:26:39

IT公司程序員鼓勵師

2021-10-21 08:30:00

1024嘉年華程序員節

2012-09-12 15:48:34

程序員節程序員

2013-06-27 10:12:47

2021-11-16 11:32:55

開發跳躍游戲

2018-08-24 07:39:46

2023-09-05 10:40:20

Meta人工智能

2022-08-19 09:53:20

人工智能大數據風險

2021-06-11 18:48:23

人工智能AI

2019-11-26 10:15:24

騰訊游戲

2011-05-10 13:37:53

程序員

2025-05-19 14:35:30

RustCTO項目

2019-12-18 14:14:40

程序員存儲程序

2024-02-07 08:00:00

算法推薦系統BPR
點贊
收藏

51CTO技術棧公眾號

亚洲天堂免费| 69堂精品视频在线播放| 成人av在线播放网站| 91sa在线看| 妖精视频在线观看免费| 国产精品日本一区二区不卡视频| 一区二区三区欧美视频| 精品视频在线观看| 一本久道久久综合无码中文| 国产精品www994| 亚洲乱码av中文一区二区| 久久99爱视频| 色多多在线观看| 国产精品嫩草久久久久| 国产66精品久久久久999小说| 五月婷婷亚洲综合| 999国产精品| 亚洲精品www久久久| 性欧美1819| 免费v片在线观看| 亚洲视频1区2区| 麻豆亚洲一区| www黄色网址| 男女性色大片免费观看一区二区 | 高清一区二区三区视频| 99re这里只有精品在线| 激情欧美丁香| 日韩视频在线免费| 免费观看av网站| 伊人久久大香线蕉av超碰| 在线看不卡av| 日本成年人网址| 免费看电影在线| 国产精品初高中害羞小美女文| 极品尤物一区二区三区| 亚洲av无码一区二区乱子伦 | 一区二区三区中文在线| 日韩亚洲视频在线| 天堂v视频永久在线播放| 国产乱码一区二区三区| 国产精品一区二区三区久久久| 免费观看成人毛片| 在线看片成人| 久久久久久国产精品美女| 少妇人妻丰满做爰xxx| 精品一区二区三区中文字幕老牛| 日韩电影中文字幕在线观看| 成人做爰www看视频软件| 久久丁香四色| 日韩一区二区三区在线视频| 精品国产鲁一鲁一区二区三区| yiren22亚洲综合| 日本韩国一区二区三区| 国产女大学生av| 超碰在线视屏| 亚洲第一精品在线| 男女视频网站在线观看| 欧美78videosex性欧美| 一区二区在线电影| 免费极品av一视觉盛宴| av免费在线免费| 伊人开心综合网| 精品成在人线av无码免费看| 欧美四级在线| 午夜精品成人在线视频| 男人操女人逼免费视频| 中文在线免费视频| 在线观看免费一区| 中文字幕在线综合| 豆花视频一区| 精品久久久久久久久久久久包黑料| 中文字幕55页| 精品国产一区二区三区不卡蜜臂| 亚洲精品久久久久中文字幕欢迎你 | 久久青青色综合| 亚洲午夜国产一区99re久久| 国产v片免费观看| 亚洲一区站长工具| 欧美亚洲图片小说| www.51色.com| 久久精品国产亚洲5555| 精品中文字幕久久久久久| 久久成人激情视频| 午夜影院欧美| 97国产成人精品视频| 天天干天天色综合| 九九九久久久精品| 国产一区二区精品在线| 黄色网址在线播放| 亚洲精品视频在线观看免费| www.av中文字幕| 欧美日韩尤物久久| 欧美成人激情免费网| 国产免费看av| 91精品国产91久久综合| 97国产精品免费视频| 中文字幕永久在线视频| 狠狠色2019综合网| 久久久久久久免费| 蜜芽在线免费观看| 欧美日韩一区二区免费在线观看| mm131国产精品| 欧美性生活一级片| 日韩中文字幕在线看| 国产精品第九页| 蜜臀av性久久久久蜜臀aⅴ流畅| 97se在线视频| 川上优的av在线一区二区| 亚洲卡通欧美制服中文| 日av中文字幕| 91九色鹿精品国产综合久久香蕉| 亚洲夜晚福利在线观看| 国产亚洲精品av| 奇米四色…亚洲| 国产伦精品一区二区三区四区免费 | 亚洲综合在线电影| 欧美成人一区二区三区在线观看| 中文字幕网站在线观看| 国产综合激情| 国产美女高潮久久白浆| 偷拍25位美女撒尿视频在线观看| 亚洲欧美日韩系列| 亚洲天堂av线| 西瓜成人精品人成网站| 欧美另类第一页| 这里只有精品免费视频| 99精品国产热久久91蜜凸| 在线视频一二三区| 91精品国产66| 亚洲网站视频福利| 可以免费看的av毛片| 成人综合在线观看| 在线观看18视频网站| 国产第一亚洲| 国产亚洲欧美视频| 婷婷激情五月网| 不卡区在线中文字幕| 免费看日b视频| 国产精品久久久久久久久久辛辛| 中文字幕九色91在线| 国产婷婷色一区二区在线观看| 成人午夜大片免费观看| 91亚洲精品国产| 一区二区三区视频播放| 欧美精品亚州精品| 99热这里是精品| 综合电影一区二区三区| jizzzz日本| 成人在线免费小视频| 国产精品日韩久久久久| 国产98在线| 欧美色综合天天久久综合精品| 亚洲国产天堂av| 日韩vs国产vs欧美| 日本亚洲欧洲精品| 久久天堂av| 日韩在线观看视频免费| 一二三区中文字幕| 亚洲视频一区二区在线| 亚洲天堂一区二区在线观看| 综合视频在线| 国产 高清 精品 在线 a| 超级碰碰不卡在线视频| 日韩成人久久久| 亚洲精品中文字幕乱码三区91| 久久婷婷国产综合国色天香| 日本www高清视频| 日本道不卡免费一区| 成人www视频在线观看| 男人的天堂在线视频免费观看 | 性色av蜜臀av| 亚洲一区二区精品久久av| 9.1在线观看免费| 一本久久综合| 日韩激情久久| 国产精品亚洲综合在线观看| 欧美精品九九久久| 你懂的在线视频| 欧美日韩久久一区二区| 男人的天堂久久久| 成人av电影在线| 三级a在线观看| 亚洲人成免费网站| 国产一区二区三区四区hd| 老司机2019福利精品视频导航| 永久免费毛片在线播放不卡| 国产精品一区二区av白丝下载| 亚洲综合网站在线观看| 亚洲天堂网一区二区| 捆绑调教一区二区三区| 大荫蒂性生交片| 亚洲系列另类av| 91色中文字幕| 综合日韩av| 久久这里有精品视频| 色婷婷中文字幕| 欧美无人高清视频在线观看| 私库av在线播放| 久久久久久一二三区| 99精品视频国产| 美女诱惑黄网站一区| 色哺乳xxxxhd奶水米仓惠香| 亚洲人成伊人成综合图片| 成人国产在线视频| 午夜影院在线观看国产主播| 久久亚洲一区二区三区四区五区高 | 欧美特黄一级片| av福利精品导航| 色戒在线免费观看| 国产亚洲一区在线| 亚洲一区精彩视频| 无码日韩精品一区二区免费| 成人午夜一级二级三级| 97久久香蕉国产线看观看| 欧美黑人xxxⅹ高潮交| 在线观看a视频| 亚洲大胆人体av| 国产强被迫伦姧在线观看无码| 欧美午夜xxx| 国产一级一级片| 中文字幕亚洲欧美在线不卡| 一级肉体全黄裸片| www.亚洲人| 男人女人拔萝卜视频| 蜜桃视频在线一区| 成人一区二区三| 一二三区精品| 日本一本中文字幕| 欧美一区二区| 强伦女教师2:伦理在线观看| 激情综合网五月| 免费影院在线观看一区| 大型av综合网站| 91美女片黄在线观看游戏| 99九九久久| 国产99在线|中文| 日本午夜大片a在线观看| 欧美激情图片区| 午夜伦理在线视频| 精品国产一区av| 在线观看的av| 一区二区三区天堂av| 可以直接在线观看的av| 精品一区二区三区四区| 天天在线女人的天堂视频| 日韩精品在线看| 欧美香蕉爽爽人人爽| 国产午夜精品理论片a级探花| 凸凹人妻人人澡人人添| 亚洲精品乱码久久久久久金桔影视 | 在线欧美一区| 青青在线视频免费观看| 欧美三级小说| 成人免费在线视频播放| 韩国自拍一区| 久草视频国产在线| 亚洲美女91| 久久9精品区-无套内射无码| 久久精品观看| 黄色在线视频网| 久久超碰97中文字幕| 亚洲综合123| 国产成人av网站| 国产一线在线观看| 91在线观看一区二区| 蜜桃精品一区二区| 26uuu精品一区二区三区四区在线| 亚洲av无码国产精品久久| 国产三区在线成人av| 亚洲欧美另类日本| 亚洲久草在线视频| www.伊人久久| 欧美无人高清视频在线观看| 国产区精品在线| 亚洲高清不卡av| 青青免费在线视频| 这里只有精品在线播放| 麻豆影视在线观看_| 色与欲影视天天看综合网| 97蜜桃久久| 国产精品精品视频一区二区三区| 久久福利在线| 亚洲一区二区三区乱码aⅴ蜜桃女| 97久久亚洲| 日韩高清国产一区在线观看| 91精品国产91久久久久久密臀| 成年女人18级毛片毛片免费| 久久字幕精品一区| 亚洲欧美一区二区三区不卡| 99国产精品国产精品久久| 欧美大波大乳巨大乳| 亚洲精品精品亚洲| 天天操夜夜操视频| 欧美嫩在线观看| 狠狠综合久久av一区二区| 亚洲美女免费精品视频在线观看| 国产福利在线播放麻豆| 5252色成人免费视频| 亚洲人体在线| 久久久99国产精品免费| 91精品国产自产在线观看永久∴ | 日韩在线不卡av| 亚洲国产成人av网| 一区二区小视频| 亚洲精品99久久久久| 成人video亚洲精品| 日韩免费黄色av| 东京久久高清| 亚洲自拍三区| 久久综合导航| 欲求不满的岳中文字幕| 中文字幕佐山爱一区二区免费| 国产91精品一区| 欧美成人a∨高清免费观看| 都市激情在线视频| 992tv成人免费影院| 精品久久久久久久久久岛国gif| 欧美下载看逼逼| 伊人精品在线| 欧洲在线免费视频| 国产精品水嫩水嫩| 日韩欧美在线观看免费| 精品久久五月天| 50度灰在线| 成人淫片在线看| 欧美中文一区二区| 国产熟女高潮视频| av在线一区二区| 国产一级在线播放| 日韩一区二区三区av| 免费大片在线观看www| 国产精品电影网| 国产探花一区| 国产成人a亚洲精v品无码| 成人国产电影网| 国产在线免费视频| 日韩精品专区在线影院重磅| 欧美13一16娇小xxxx| 成人激情免费在线| 欧美国产一区二区三区激情无套| 992kp快乐看片永久免费网址| 26uuu国产在线精品一区二区| 国产第一页第二页| 精品国产99国产精品| 欧美xxxx做受欧美88bbw| 97视频中文字幕| 欧美日韩精品| 性生交大片免费看l| 一区二区三区在线播| 亚洲成人久久精品| 久久6免费高清热精品| 亚洲大奶少妇| www.成年人视频| 不卡的电视剧免费网站有什么| 九热这里只有精品| 日韩av在线播放资源| 中文字幕在线视频久| 欧美极品色图| 日精品一区二区| 亚洲激情图片网| 777午夜精品免费视频| av在线导航| 国产二区一区| 亚洲综合丁香| 日本一区二区视频在线播放| 欧美性色综合网| 黄色精品免费看| 国产精品theporn88| 国产亚洲福利| 欧洲av一区二区三区| 欧美高清www午色夜在线视频| 综合久久2o19| 精品高清视频| 青青草成人在线观看| 全网免费在线播放视频入口| 精品福利在线导航| 久九九久频精品短视频| 亚洲免费视频一区| 国产成人精品一区二区三区四区 | 在线观看欧美黄色| 成人日韩欧美| 精品午夜一区二区三区| 美女网站一区二区| 免费在线观看黄色av| 国产手机视频精品| 亚洲tv在线| 久久视频这里有精品| 国产欧美精品一区二区色综合| 国产精品久久免费| 欧美在线一区二区视频| 香蕉综合视频| 一级性生活大片| 欧美精品久久一区| 高清精品在线| 在线综合视频网站| 91在线国产观看| av中文字幕免费| 日本伊人精品一区二区三区介绍| 国产精品91一区二区三区| 中文字幕免费高清视频|