php实现的微信红包算法分析非官方

本文实例讲述了PHP实现的微信红包算法。分享给大家供大家参考。具体如下:

最近一直在微信群里体验红包功能,红包类型有两种:

1. 普通红包

2. 拼手气红包

普通红包就不用多解析了,大锅饭原理,平分。

拼手气红包讲的是手气(运气),有人可以抢到很多,有人抢的少得可怜,当然也不是先抢就一定多,说到底了就是随机

想了想,自己写写看,能不能实现类似的功能(不敢说是算法)。

rush:PHP;"> // $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; }

好吧,我们现在来体验一下

rush:PHP;"> // 发3个拼手气红包,总金额是100元 $bonus_items = randBonus(100,3,1); // 查看生成的红包 var_dump($bonus_items); // 校验总金额是不是正确,看看微信有没有坑我们的钱 var_dump(array_sum($bonus_items));

一个使用数组实现的版本,原理差不多:

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程序设计有所帮助。

相关文章

统一支付是JSAPI/NATIVE/APP各种支付场景下生成支付订单,返...
统一支付是JSAPI/NATIVE/APP各种支付场景下生成支付订单,返...
前言 之前做了微信登录,所以总结一下微信授权登录并获取用户...
FastAdmin是我第一个接触的后台管理系统框架。FastAdmin是一...
之前公司需要一个内部的通讯软件,就叫我做一个。通讯软件嘛...
统一支付是JSAPI/NATIVE/APP各种支付场景下生成支付订单,返...