时间:2021-07-01 10:21:17 帮助过:3人阅读
我们先来分析下规律。 设定总金额为10元,有N个人随机领取: N=1 第一个 则红包金额=X元; N=2 第二个 为保证第二个红包可以正常发出,第一个红包金额=0.01至9.99之间的某个随机数。 第二个红包=10-第一个红包金额; N=3 第三个 红包1=0.01至9.99之间的某个随机数 红包2=0.01至(10-红包1-0.01)的某个随机数 红包3=10-红包1-红包2 …… 于是我们得到一个规律,在分配当前红包金额时,先预留剩余红白所需最少金额,然后在0.01至总金额-预留金额间取随机数,得到的随机数就是当前红包分配的金额。 实际应用中,程序先将红包金额分配好,即发红包时,红包个数以及每个红包的金额都分配好了,那么用户来抢红包时,我们随机给用户返回一个红包即可。 红包分配代码:
运行以上代码,会输出以下结果: 第1个红包,金额2.08元,余额17.92元 第2个红包,金额1.81元,余额16.11元 第3个红包,金额0.15元,余额15.96元 第4个红包,金额1.61元,余额14.35元 第5个红包,金额1.11元,余额13.24元 第6个红包,金额1.51元,余额11.73元 第7个红包,金额1.21元,余额10.52元 第8个红包,金额2.58元,余额7.94元 第9个红包,金额5.4元,余额2.54元 第10个红包,金额2.54元,余额0元 原文 http://www.helloweba.com/view-blog-313.html |