<?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;
}