`
天梯梦
  • 浏览: 13623354 次
  • 性别: Icon_minigender_2
  • 来自: 洛杉矶
社区版块
存档分类
最新评论

微信红包的算法实现探讨(基于PHP)

 
阅读更多

今晚突发奇想给校友微信群发了红包,我设定红包总额为10元,支持28个人随机领取。

于是一个有趣的结果出现了:

A 领取了 0.26元
B 领取了 0.29元
C 领取了 0.02元
D 领取了 0.56元
E 领取了 0.64元
……

微信是采用什么样的算法做到的?简单百度了下,目前尚未有官方的说明,仅仅在知乎里有一个较为热门的讨论,链接戳这里,不过他们讨论的太过于深入,有掉坑之嫌。

我按照自己的逻辑尝试了下,这个算法需要满足以下几点要求:

1、每个人都要能够领取到红包;

2、每个人领取到的红包金额总和=总金额;

3、每个人领取到的红包金额不等,但也不能差的太离谱,不然就没趣味;

4、算法一定要简单,不然对不起腾讯这个招牌;

正式编码之前,先搭建一个递进的模型来分析规律

设定总金额为10元,有N个人随机领取:
N=1 
则红包金额=X元; 

N=2 
为保证第二个红包可以正常发出,第一个红包金额=0.01至9.99之间的某个随机数 
第二个红包=10-第一个红包金额; 

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

……

 

至此,规律出现啦!开始编码!

header("Content-Type: text/html;charset=utf-8");//输出不乱码,你懂的
$total=10;//红包总额
$num=8;// 分成8个红包,支持8人随机领取
$min=0.01;//每个人最少能收到0.01元

for ($i=1;$i<$num;$i++)
{
    $safe_total=$total-($num-$i)*$min;//随机安全上限
    $money=mt_rand($min*100,$safe_total*100)/100;
    $total=$total-$money;
    echo '第'.$i.'个红包:'.$money.' 元,余额:'.$total.' 元 <br/>';
}
echo '第'.$num.'个红包:'.$total.' 元,余额:0 元';

 

输入一看,波动太大,这数据太无趣了!

第1个红包:7.48 元,余额:2.52 元 
第2个红包:1.9 元,余额:0.62 元 
第3个红包:0.49 元,余额:0.13 元 
第4个红包:0.04 元,余额:0.09 元 
第5个红包:0.03 元,余额:0.06 元 
第6个红包:0.03 元,余额:0.03 元 
第7个红包:0.01 元,余额:0.02 元 
第8个红包:0.02 元,余额:0 元

 

改良一下,将平均值作为随机安全上限来控制波动差

header("Content-Type: text/html;charset=utf-8");//输出不乱码,你懂的
$total=10;//红包总额
$num=8;// 分成8个红包,支持8人随机领取
$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.' 元 <br/>';
}
echo '第'.$num.'个红包:'.$total.' 元,余额:0 元';

 

输出结果见下图

第1个红包:0.06 元,余额:9.94 元 
第2个红包:1.55 元,余额:8.39 元 
第3个红包:0.25 元,余额:8.14 元 
第4个红包:0.98 元,余额:7.16 元 
第5个红包:1.88 元,余额:5.28 元 
第6个红包:1.92 元,余额:3.36 元 
第7个红包:2.98 元,余额:0.38 元 
第8个红包:0.38 元,余额:0 元

 

阅读原文

分享到:
评论
2 楼 天梯梦 2015-11-19  
dishajk 写道
这个算法是不是复杂了?发红包的时候直接随机分成N份,然后用户抢只是随机取这些分好的红包即可,像抓阄。
你这个抢一次算一次,服务器要累死了!


随机分成N份,难道你不用计算余额吗? 你的随机分法是什么呢? 贴一下你的算法看看呗...
1 楼 dishajk 2015-11-18  
这个算法是不是复杂了?发红包的时候直接随机分成N份,然后用户抢只是随机取这些分好的红包即可,像抓阄。
你这个抢一次算一次,服务器要累死了!

相关推荐

    基于PHP微信红包的算法探讨_.docx

    基于PHP微信红包的算法探讨_.docx

    微信红包封面制作小程序源码 新手小白适用

    微信红包封面制作小程序源码。新手小白适用微信红包封面制作小程序源码。新手小白适用微信红包封面制作小程序源码。新手小白适用微信红包封面制作小程序源码。新手小白适用微信红包封面制作小程序源码。新手小白适用...

    微信红包程序实现代码

    该程序基本实现了微信红包程序,红包金额为吉利数字,分布比较均匀。 程序解释文章请看 https://blog.csdn.net/weixin_43347550/article/details/105227159 微信红包程序:给定一个钱数m,发红包人数n,其中10, n将...

    PHP仿微信红包[最佳手气]算法

    * 拼手气红包实现方法[并做手气最佳处理] * 生成num个随机数,每个随机数占随机数总和的比例*money_total的值即为每个红包的钱额 * 考虑到精度问题,最后重置最大的那个红包的钱额为money_total-其他红包的总额 ...

    微信红包营销系统php版v1.0

    适用范围:微信红包营销系统|1分钱微信红包系统|1块钱微信红包营销系统 运行环境:PHP5.2 MYsql(php版本为版主调试的时候确定的版本,请一定注意) 程序介绍:7月最新微信红包营销系统|1分钱微信红包系统|1块钱微信...

    php实现微信红包接口

    利用php技术简单实现微信红包接口,关注得红包的demo 很不错的

    自动抢微信红包.zip

    自动抢微信红包.zip自动抢微信红包.zip自动抢微信红包.zip自动抢微信红包.zip 自动抢微信红包.zip自动抢微信红包.zip自动抢微信红包.zip自动抢微信红包.zip 自动抢微信红包.zip自动抢微信红包.zip自动抢微信红包.zip...

    php实现的微信红包算法分析(非官方)

    本文实例讲述了php实现的微信红包算法。分享给大家供大家参考。具体如下: 最近一直在微信群里体验红包功能,红包类型有两种: 1. 普通红包 2. 拼手气红包 普通红包就不用多解析了,大锅饭原理,平分。 拼手气红包讲...

    PHP微信红包生成代码分享

    主要介绍了PHP微信红包API接口,针对PHP微信公众号自动发送红包API,PHP微信红包API接口的主要代码进行分析,感兴趣的小伙伴们可以参考一下

    微信红包的原理

    讲解微信红包的原理,包括发放以及收取红包的原理,讲解很好

    微信红包辅助(快速开红包,利用无障碍服务实现的微信自用抢红包辅助).zip

    微信红包辅助(快速开红包,利用无障碍服务实现的微信自用抢红包辅助).zip 微信红包辅助(快速开红包,利用无障碍服务实现的微信自用抢红包辅助).zip 微信红包辅助(快速开红包,利用无障碍服务实现的微信自用抢...

    基于Android的监听微信红包+自动抢红包(抢红包必备助手)).zip

    基于Android的监听微信红包+自动抢红包(抢红包必备助手)(利用AccessibilityService这个辅助服务类,监听通知栏微信消息,如果有微信红包,就模拟界面一些控件的点击事件).zip 基于Android的监听微信红包+自动抢...

    html+css+js 仿微信红包

    html+css+js 仿微信红包

    Python版微信红包分配算法

    微信红包告诉你,学好数学,真的可以多抢红包!!下面就和大家分享一下抢红包的秘籍,简单概括就是:让朋友先上!

    php微信接口sign算法.zip

    微信接口算法: sign是基于每次交互的数据和商户平台设置的密钥key来计算的。 需要数组首字母排序,拼接数组,拼接key,加密换算来完成。

    PHP用抛物线的模型实现微信红包生成算法的程序源码

    以前研究的红包的生成算法,看似觉得简单,实际弄起来不是那么回事,当然如果只是...资源为个人使用 PHP 开发的抛物线的模型实现微信红包生成算法的程序源码 。个人CSDN中也有一篇相关的技术文章,可以对照文章查看。

    微信红包的架构设计简介

    微信红包的架构设计简介。学习高并发 装逼利器。

    微信红包营销系统

    适用范围:微信红包营销系统|1分钱微信红包系统|1块钱微信红包营销系统 运行环境:PHP5.2+MYsql(php版本为版主调试的时候确定的版本,请一定注意) 程序介绍:7月最新微信红包营销系统|1分钱微信红包系统|1块钱微信...

Global site tag (gtag.js) - Google Analytics