=num*0.01原理如下,從1~money*100的數(shù)的集合中,隨機抽取num-1個數(shù),然后對這些數(shù)進行排序,在排序后的集合前后分別插入0和money*100,組成新的集合用新的集合,(后一個數(shù)-前一個數(shù))/100得到紅包的大小然后使用紅包的時候,從num個紅包集合中隨機拿一個,既是隨機紅包了defredbags(money,num=10):importrandomchoice=random" />

欧美三区_成人在线免费观看视频_欧美极品少妇xxxxⅹ免费视频_a级毛片免费播放_鲁一鲁中文字幕久久_亚洲一级特黄

python生成隨機紅包的實例寫法

系統(tǒng) 1931 0

假設(shè)紅包金額為money,數(shù)量是num,并且紅包金額money>=num*0.01

原理如下,從1~money*100的數(shù)的集合中,隨機抽取num-1個數(shù),然后對這些數(shù)進行排序,在排序后的集合前后分別插入0和money*100,組成新的集合

用新的集合,(后一個數(shù)-前一個數(shù))/100得到紅包的大小

然后使用紅包的時候,從num個紅包集合中隨機拿一個,既是隨機紅包了

            
def redbags(money, num=10):
  import random
  choice = random.sample(range(1, money * 100), num - 1)
  choice.extend([0,money*100])
  choice.sort()
  return [(choice[i + 1] - choice[i]) / 100 for i in range(num)]
          

擴展內(nèi)容:

進入紅包思路主題

好了前面簡單的介紹玩今天要使用的工具該進入正題說說紅包的思路了,在你發(fā)紅包的時候要填寫兩個重要參數(shù)就是紅包的金額我命名為cash,人數(shù)person,在就要思考重要的一點就是紅包的最大值和最小值,不會有點紅包領(lǐng)到0吧,一般0.01為最小值,為什么會來說還有最大值,你想假如一個10塊的紅包6個人搶第一個能搶了9.99,那么第二個人只有剩下0.01,后面的人沒得強,這不就有問題了。所以最大值應(yīng)該就是紅包總金額減去最小值乘以人數(shù)(10-0.01x6)這樣才保證大家都有得搶當然最貪婪的寫法是10-0.01x5有人會問為什么是5,已經(jīng)把第一個人排除剩下五個最慘的結(jié)局都是0.01。基本你掌握這個思路就好寫代碼了看看如下:

            
#!/usr/bin/env python
# -*-coding:utf-8 -*-
 
import random
 
dic={}
lis = ['KeLan','Monkey','Dexter','Superman','Iron Man','Robin']
 
def redpacket(cash,person,index):
  if cash>0 and person !=1:
    n = round(random.uniform(0.01,cash-(0.01*person)),2)
    dic[lis[index]] = n
    print str(n).ljust(4,"0")
    person-=1
    cash-=n
    index+=1
    redpacket(cash,person,index)
  else:
    dic[lis[index]]=round(cash,2)
    print str(cash).ljust(4,"0")
 
redpacket(10,len(lis),0)
print dic
print "手氣最佳:",max(dic.items(),key=lambda x:x[1])
          

我在這里用的是遞減的方式來遞歸剩余的錢數(shù)與人數(shù),加了個判斷防止無限遞歸。只要錢cash大于0并且person剩余人數(shù)不是1那么繼續(xù)往下走:n是隨機浮點數(shù),范圍是從最小的0.01到當前的金額,round是取小數(shù)點后保留2位,這字典用來存放相應(yīng)的人搶了多少紅包金額,然后人數(shù)自減少1,金額自減當前搶走的金額index是從人名中順序取值(當然實際不會按找順序搶,這里只是掩飾介紹過程),然后遞歸調(diào)用自己把剩余的錢cash,剩余人數(shù)person,新位置的人重新傳參,如果剩下最后一個人(測試了50次,沒有發(fā)現(xiàn)金額小于0的情況所以這里只表述人)那么剩下的錢就都是他的并且添加到字典,打印輸出,由于else內(nèi)沒調(diào)用自身遞歸自然結(jié)束最后打印字典的包含了人與搶紅包金額對應(yīng),最后要答應(yīng)手氣最佳的人用max從列表中取最大值dic.items()返回以元組形式一一對應(yīng)的列表[(person人,cash錢)],lambda寫的是取每個元素的的1位置來做比較也是就是cash值來做比較,max拿出列表中最大的元組。

以上就是本次介紹的全部知識點內(nèi)容,感謝大家對腳本之家的支持。


更多文章、技術(shù)交流、商務(wù)合作、聯(lián)系博主

微信掃碼或搜索:z360901061

微信掃一掃加我為好友

QQ號聯(lián)系: 360901061

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點擊下面給點支持吧,站長非常感激您!手機微信長按不能支付解決辦法:請將微信支付二維碼保存到相冊,切換到微信,然后點擊微信右上角掃一掃功能,選擇支付二維碼完成支付。

【本文對您有幫助就好】

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描上面二維碼支持博主2元、5元、10元、自定義金額等您想捐的金額吧,站長會非常 感謝您的哦!!!

發(fā)表我的評論
最新評論 總共0條評論
主站蜘蛛池模板: 成人在线免费视频观看 | 中文字幕精品视频 | 欧美黄色一区 | 亚洲欧美日韩在线一区二区三区 | 欧美高潮| 人人狠狠 | 成人黄色短视频在线观看 | 日韩电影一区二区三区 | 欧美色欧美色 | 三级全黄a | 国产乱码一区二区三区四 | 偷拍自拍在线播放 | 国产精品高潮呻吟久久av黑人 | 九九免费视频 | 女人叉开腿让男人桶 | 91免费在线看 | 亚洲AV在线无码播放毛片浪潮 | 国产精品岛国久久久久久久 | 久久久久毛片成人精品 | 看片国产 | 欧美一区欧美二区 | 天堂在线www网亚洲 欧美 日韩 | 天天色天天色 | 国产三级在线精品男人的天堂 | 色图综合 | 亚洲成人一区二区 | 久久er精品| 欧美精品18| 天天色天天色 | 日本黄色a视频 | 国产高清视频一区二区 | 日本黄色福利视频 | 久久国产免费 | 97精品超碰一区二区三区 | 亚洲一区在线观看视频 | 国产精品嫩草影视在线观看 | 性欧美激情在线观看 | 青娱乐国产精品 | 日出水了视频大全 | 日韩精品区 | 欧美成人h版在线观看 |