<?php header("Content-type: text/html; charset=utf-8"); $result = $result2 = randHB(0.06, 5); echo '随机效果'; var_export($result); echo "<br />\r\n"; echo '红包总额:'; echo array_sum($result); echo "<br />\r\n"; echo '降序排序'; arsort($result2); print_r($result2); /** * 拼手气红包实现[处理最佳手气] * 生成num个随机数,每个随机数占随机数总和的比例*money_total的值即为每个红包的钱额 * 考虑到精度问题,最后重置最大的那个红包的钱额为money_total-其他红包的总额 * 浮点数比较大小,使用number_format,精确到2位小数 * * @author Loy * * @param double $money_total 总钱额, 每人最少0.01,精确到2位小数 * @param int $num 发送给几个人 * @return array num个元素的一维数组,值是随机钱额 */ function randHB($money_total, $num) { if($money_total < $num*0.01) { exit('钱太少'); } $rand_arr = array(); for($i=0; $i<$num; $i++) { $rand = rand(1, 100); $rand_arr[] = $rand; } $rand_sum = array_sum($rand_arr); $rand_money_arr = array(); $rand_money_arr = array_pad($rand_money_arr, $num, 0.01); //保证每个红包至少0.01 foreach ($rand_arr as $key => $r) { $rand_money = number_format($money_total*$r/$rand_sum, 2); if($rand_money <= 0.01 || number_format(array_sum($rand_money_arr), 2) >= number_format($money_total, 2)) { $rand_money_arr[$key] = 0.01; } else { $rand_money_arr[$key] = $rand_money; } } $max_index = $max_rand = 0; foreach ($rand_money_arr as $key => $rm) { if($rm > $max_rand) { $max_rand = $rm; $max_index = $key; } } unset($rand_money_arr[$max_index]); //这里的array_sum($rand_money_arr)一定是小于$money_total的 $rand_money_arr[$max_index] = number_format($money_total - array_sum($rand_money_arr), 2); ksort($rand_money_arr); //尽量算出最佳手气,如果第一名和第二名相等并且不等于0.01元时,把第一名减0.01元,第二名加0.01元 if ($num > 1) { $top_rand_money_arr = $rand_money_arr; arsort($top_rand_money_arr); $top_1 = $top_2 = 0; $num_sort = 1; foreach ($top_rand_money_arr as $key => $val) { if ($num_sort==1) { $top_1 = $val; $top_key_1 = $key; } if ($num_sort==2) { $top_2 = $val; $top_key_2 = $key; } if ($num_sort>2) { break; } $num_sort ++; } if ($top_1 == $top_2 && ($top_1<>0.01)) { $top_rand_money_arr[$top_key_1] = number_format(($top_1 + 0.01), 2); $top_rand_money_arr[$top_key_2] = number_format(($top_2 - 0.01), 2); } } else { $top_rand_money_arr = $rand_money_arr; } ksort($top_rand_money_arr); return $top_rand_money_arr; }