本文实例讲述了php实现的微信红包算法。分享给大家供大家参考。具体如下:
最近一直在微信群里体验红包功能,红包类型有两种:
1. 普通红包
2. 拼手气红包
普通红包就不用多解析了,大锅饭原理,平分。
拼手气红包讲的是手气(运气),有人可以抢到很多,有人抢的少得可怜,当然也不是先抢就一定多,说到底了就是随机。

想了想,自己写写看,能不能实现类似的功能(不敢说是算法)。
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 | 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 ;
}
|
ログイン後にコピー
好吧,我们现在来体验一下
1 2 3 4 5 6 | $bonus_items = randBonus(100, 3, 1);
var_dump( $bonus_items );
var_dump( array_sum ( $bonus_items ));
|
ログイン後にコピー
另一个使用数组实现的版本,原理差不多:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 | 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程序设计有所帮助。