红包分配

来源:互联网 发布:一句话木马 php提权 编辑:程序博客网 时间:2024/04/29 12:29

不多说,直接上一个红包分配的代码

// 红包个数$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);

这样效果会好很多,基本能保持在平均值左右了。

更好的算法还有很多,用于基础交流。有不正确的地方欢迎私聊。

原创粉丝点击