首先來說說要用到的知識(shí)點(diǎn),第一個(gè)要說的是擴(kuò)展包random,random模塊一般用來生成一個(gè)隨機(jī)數(shù)

今天要用到ramdom中unifrom的方法用于生成一個(gè)指定范圍的隨機(jī)浮點(diǎn)數(shù)通過下面的圖簡單看下:

這里就打印了一個(gè)值范圍是在10~20之間的浮點(diǎn)數(shù)。


 

在來說說lambda表達(dá)式是匿名函數(shù),是函數(shù)的另一種表達(dá)方式,以下清晰了介紹了使用效果:

t函數(shù)有3個(gè)值,返回3個(gè)數(shù)之和,f是lambda表達(dá)式,作用同樣是返回三個(gè)數(shù)只和,def 類似 lambda,t類似f, (x,y,z):類似x,y,z:, return x+y+z類似:x+y+z  最后都調(diào)用函數(shù)返回其和不過在此提醒函數(shù)可以寫很復(fù)雜,lambda寫復(fù)雜了就不容易理解,代碼畢竟簡單易懂為先。


 

進(jìn)入紅包思路主題

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

復(fù)制代碼
#!/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])
復(fù)制代碼

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

來看看最后打印效果如下

是不是簡單清晰,最后大家可以多試試效果,我在此只是把自己的思路與大家分享了一下,當(dāng)然大家有好的建議修改或者更優(yōu)化的方式在后面留言,互相學(xué)習(xí)。感謝大家的觀看。