科技

Python寫隨機發紅包的原理流程

Python寫隨機發紅包的原理流程

首先來說說要用到的知識點,第一個要說的是擴充套件包random,random模組一般用來生成一個隨機數

今天要用到ramdom中unifrom的方法用於生成一個指定範圍的隨機浮點數通過下面的圖簡單看下:

這裡就列印了一個值範圍是在10~20之間的浮點數。

在來說說lambda表示式是匿名函式,是函式的另一種表達方式,以下清晰了介紹了使用效果:

t函式有3個值,返回3個數之和,f是lambda表示式,作用同樣是返回三個數只和,def 類似 lambda,t類似f, (x,y,z):類似x,y,z:, return x+y+z類似:x+y+z 最後都呼叫函式返回其和不過在此提醒函式可以寫很複雜,lambda寫複雜了就不容易理解,程式碼畢竟簡單易懂為先。

進入紅包思路主題

好了前面簡單的介紹玩今天要使用的工具該進入正題說說紅包的思路了,在你發紅包的時候要填寫兩個重要引數就是紅包的金額我命名為cash,人數person,在就要思考重要的一點就是紅包的最大值和最小值,不會有點紅包領到0吧,一般0.01為最小值,為什麼會來說還有最大值,你想假如一個10塊的紅包6個人搶第一個能搶了9.99,那麼第二個人只有剩下0.01,後面的人沒得強,這不就有問題了。所以最大值應該就是紅包總金額減去最小值乘以人數(10-0.01x6)這樣才保證大家都有得搶當然最貪婪的寫法是10-0.01x5有人會問為什麼是5,已經把第一個人排除剩下五個最慘的結局都是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])

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

來看看最後列印效果如下

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

Reference:科技日報

看更多!請加入我們的粉絲團

轉載請附文章網址

不可錯過的話題