php 实现随机群发红包 -

版权声明:本文的所有内容,包括文字,图片,均为原创。对未经许可擅自使用转载者,本人保留追究其法律责任的权利。 https://blog.csdn.net/jxwBlog/article/details/80946087

文章简介

本文讲的是用PHP实现随机群发红包。使用PHP发红包时,当我们输入红包数量和总金额后,PHP会根据这两个值进行随机分配每个金额,保证每个人都能领取到一个红包,每个红包金额不等,就是要求红包金额要有差异,所有红包金额总额应该等于总金额。

红包代码逻辑分析

我们先来分析下规律~

设定总金额为10元,有N个人随机领取:

N=1 第一个

为保证第二个红包可以正常发出,第一个红包金额=0.01至10-0.01*(10-1)之间的某个随机数。

N=2 第二个

为保证第三个红包可以正常发出,第二个红包金额=0.01至10-0.01*(10-2)之间的某个随机数。

N=3 第三个

为保证第四个红包可以正常发出,第三个红包金额=0.01至10-0.01*(10-3)之间的某个随机数。

总结以上即:

红包1=0.01至10-0.01*(10-1)之间的某个随机数;

红包2=0.01至(10-红包1-0.01*(10-2))之间的某个随机数;

红包3=0.01至(10-红包1-红包2-0.01*(10-3))之间的某个随机数;

……

于是我们得到一个规律,在分配当前红包金额时,先预留剩余红白所需最少金额,然后在0.01至总金额-预留金额间取随机数,得到的随机数就是当前红包分配的金额。

实际应用中,程序先将红包金额分配好,即发红包时,红包个数以及每个红包的金额都分配好了,那么用户来抢红包时,我们随机给用户返回一个红包即可。

代码实例

$total=10;//红包总金额  
$num=10;// 分成10个红包,支持10人随机领取  
$min=0.01;//每个人最少能收到0.01元  

for ($i=1;$i<$num;$i++)  
{  
    $safe_total=($total-($num-$i)*$min)/($num-$i);//随机安全上限  
    $money=mt_rand($min*100,$safe_total*100)/100;  
    $total=$total-$money; 

    echo '第'.$i.'个红包:'.$money.' 元,余额:'.$total.' 元 
';  
}  
echo '第'.$num.'个红包:'.$total.' 元,余额:0 元';  
输出结果:

1个红包:0.57 元,余额:9.43元
第2个红包:0.38 元,余额:9.05元
第3个红包:1.18 元,余额:7.87元
第4个红包:1.2 元,余额:6.67元
第5个红包:1.01 元,余额:5.66元
第6个红包:0.87 元,余额:4.79元
第7个红包:1.53 元,余额:3.26元
第8个红包:0.2 元,余额:3.06元
第9个红包:0.53 元,余额:2.53元
第10个红包:2.53 元,余额:0 元

猜你喜欢

转载自blog.csdn.net/jxwBlog/article/details/80946087