本文主要介紹了php實現的微信紅包演算法,以實例形式分析了拼手氣紅包的相關隨機演算法技巧。希望對大家有幫助。
具體如下:
最近一直在微信群組裡體驗紅包功能,紅包型別有兩種:
1. 普通紅包
2. 拼手氣紅包
一般紅包就不用多解析了,大鍋飯原理,平分。
拼手氣紅包講的是手氣(運氣),有人可以搶到很多,有人搶的少得可憐,當然也不是先搶就一定多,說到底了就是隨機。
想了想,自己寫寫看,能不能實現類似的功能(不敢說是演算法)。
// $bonus_total 红包总金额 // $bonus_count 红包个数 // $bonus_type 红包类型 1=拼手气红包 0=普通红包 function randBonus($bonus_total=0, $bonus_count=3, $bonus_type=1){ $bonus_items = array(); // 将要瓜分的结果 $bonus_balance = $bonus_total; // 每次分完之后的余额 $bonus_avg = number_format($bonus_total/$bonus_count, 2); // 平均每个红包多少钱 $i = 0; while($i<$bonus_count){ if($i<$bonus_count-1){ $rand = $bonus_type?(rand(1, $bonus_balance*100-1)/100):$bonus_avg; // 根据红包类型计算当前红包的金额 $bonus_items[] = $rand; $bonus_balance -= $rand; }else{ $bonus_items[] = $bonus_balance; // 最后一个红包直接承包最后所有的金额,保证发出的总金额正确 } $i++; } return $bonus_items; }
好吧,我們現在來體驗一下
// 发3个拼手气红包,总金额是100元 $bonus_items = randBonus(100, 3, 1); // 查看生成的红包 var_dump($bonus_items); // 校验总金额是不是正确,看看微信有没有坑我们的钱 var_dump(array_sum($bonus_items));
另一個使用陣列實作的版本,原理差不多:
function sendRandBonus($total=0, $count=3, $type=1){ if($type==1){ $input = range(0.01, $total, 0.01); if($count>1){ $rand_keys = (array) array_rand($input, $count-1); $last = 0; foreach($rand_keys as $i=>$key){ $current = $input[$key]-$last; $items[] = $current; $last = $input[$key]; } } $items[] = $total-array_sum($items); }else{ $avg = number_format($total/$count, 2); $i = 0; while($i<$count){ $items[] = $i<$count-1?$avg:($total-array_sum($items)); $i++; } } return $items; }
相關推薦:
#PHP實作迪菲赫曼金鑰交換(Diffie–Hellman)演算法
#以上是php實作的隨機紅包演算法的詳細內容。更多資訊請關注PHP中文網其他相關文章!