再谈微信抢红包算法

发出一个固定金额的红包,由若干个人来抢,需要满足哪些规则?

1.所有人抢到金额之和等于红包金额,不能超过,也不能少于。

2.每个人至少抢到一分钱。

3.要保证所有人抢到金额的几率相等。

 

总的来说就两种方法

1. 看上去拼手速的算法:线段切割算法

2. 比较公平的算法,二倍均值法

 

微信采用二倍均值法实现,说了是拍脑袋的算法,没有去玩统计证明。
 

 

 

640?wx_fmt=jpeg

 

640?wx_fmt=jpeg

(但是可以证明,每个人抢到的金额还是等可能的)

为什么这么说呢?让我们看一个栗子:

假设有10个人,红包总额100元。

第一个人的随机范围是(0,100元),平均可以抢到50元

假设第一个人随机到50元,那么剩余金额是100-50 = 50 元。

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值