不多说,直接上一个红包分配的代码
// 红包个数
$num = 10;
// 红包金额数
$money = 10;
// 设置预留金额
$last = $num/100;
// 用于存储红包金额
$arr = array();
// 记录已经分配出去的金额
$m = 0;
for($i=0;$i<($num-1);$i++) // 分配除了最后一个红包以外的其他红包
{
// 随机分配出红包
$a = ceil(($money - $last - $m) * (rand(0,$num)/$num)*100)/100;
// 保证单个红包最小0.01元
if ($a == 0) {
$a=0.01;
$last = $last - $a;
}
// 统计已经分配出去金额
$m = $m+$a;
$arr[] = $a;
}
// 总金额减去已经分配出去的金额为最后一个红包金额
$arr[] = round(($money-$m)*100)/100;
var_dump($arr);
然后上面这段代码红包分配可能不会很均匀,可能会出现某个红包特别大,其他一丢丢的情况,需要作出修改。针对每次分配金额设置上限
// 红包个数
$num = 10;
// 红包金额数
$money = 10;
// 设置预留金额 用于保证每个人最少领0.01元
$last = $num/100;
// 用于存储红包金额
$arr = array();
// 记录已经分配出去的金额
$m = 0;
for($i=0;$i<($num-1);$i++) // 分配除了最后一个红包以外的其他红包
{
// 计算当次分配金额 总金额减去预留金额 减去已经分配出去的金额 求出剩下的平均红包金额的2倍
$total = ($money - $last - $m)/($num-$i)*2;
// 随机分配出红包
$a = ceil($total * (rand(0,$num)/$num)*100)/100;
// 保证单个红包最小0.01元
if ($a == 0) {
$a=0.01;
$last = $last - $a;
}
// 统计已经分配出去金额
$m = $m+$a;
$arr[] = $a;
}
// 总金额减去已经分配出去的金额为最后一个红包金额
$arr[] = round(($money-$m)*100)/100;
var_dump($arr);
echo array_sum($arr);
这样效果会好很多,基本能保持在平均值左右了。
更好的算法还有很多,用于基础交流。有不正确的地方欢迎私聊。