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


Posted in PHP onJuly 21, 2016

突发奇想给校友微信群发了红包,我设定红包总额为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

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

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 元 

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

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 元

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

PHP 相关文章推荐
用PHP和ACCESS写聊天室(二)
Oct 09 PHP
某大型网络公司应聘时的笔试题目附答案
Mar 27 PHP
php 计算两个时间戳相隔的时间的函数(小时)
Dec 18 PHP
PHP函数常用用法小结
Feb 08 PHP
检查url链接是否已经有参数的php代码 添加 ? 或 &amp;
Feb 09 PHP
Windows下安装Memcached的步骤说明
Apr 25 PHP
通过JavaScript或PHP检测Android设备的代码
Mar 09 PHP
用Zend Studio+PHPnow+Zend Debugger搭建PHP服务器调试环境步骤
Jan 19 PHP
ThinkPHP的L方法使用简介
Jun 18 PHP
解密ThinkPHP3.1.2版本之模块和操作映射
Jun 19 PHP
详谈phpAdmin修改密码后拒绝访问的问题
Apr 03 PHP
PHP实现时间比较和时间差计算的方法示例
Jul 24 PHP
php中preg_replace_callback函数简单用法示例
Jul 21 #PHP
PHP获取客户端及服务器端IP的封装类
Jul 21 #PHP
thinkPHP多域名情况下使用memcache方式共享session数据的实现方法
Jul 21 #PHP
PHP获取当前文件的父目录方法汇总
Jul 21 #PHP
功能强大的php分页函数
Jul 20 #PHP
PHP转换文本框内容为HTML格式的方法
Jul 20 #PHP
PHP图形计数器程序显示网站用户浏览量
Jul 20 #PHP
You might like
浅析php与数据库代码开发规范
2013/08/08 PHP
分享下php5类中三种数据类型的区别
2015/01/26 PHP
使用jquery为table动态添加行的实现代码
2011/03/30 Javascript
jQuery之排序组件的深入解析
2013/06/19 Javascript
JavaScript简介
2015/02/15 Javascript
javascript解决IE6下hover问题的方法
2015/07/28 Javascript
如何解决IONIC页面底部被遮住无法向上滚动问题
2016/09/06 Javascript
浅谈vue-router 路由传参的方法
2017/12/27 Javascript
Angular2 父子组件通信方式的示例
2018/01/29 Javascript
Vue中v-for的数据分组实例
2018/03/07 Javascript
vue+axios新手实践实现登陆的示例代码
2018/06/06 Javascript
基于vue-cli npm run build之后vendor.js文件过大的解决方法
2018/09/27 Javascript
详解jQuery获取特殊属性的值以及设置内容
2018/11/14 jQuery
从0到1构建vueSSR项目之node以及vue-cli3的配置
2019/03/07 Javascript
微信小程序tabBar 返回tabBar不刷新页面
2019/07/25 Javascript
vue项目中使用AES实现密码加密解密(ECB和CBC两种模式)
2019/08/12 Javascript
Python爬取Coursera课程资源的详细过程
2014/11/04 Python
12步入门Python中的decorator装饰器使用方法
2016/06/20 Python
Python元字符的用法实例解析
2018/01/17 Python
python调用API实现智能回复机器人
2018/04/10 Python
python 按照固定长度分割字符串的方法小结
2018/04/30 Python
利用python库在局域网内传输文件的方法
2018/06/04 Python
浅谈Python中eval的强大与危害
2019/03/13 Python
解决pytorch GPU 计算过程中出现内存耗尽的问题
2019/08/19 Python
django框架中ajax的使用及避开CSRF 验证的方式详解
2019/12/11 Python
高清屏下canvas重置尺寸引发的问题的解决
2019/10/14 HTML / CSS
荷兰家电购物网站:Expert.nl
2020/01/18 全球购物
Linux机考试题
2015/07/17 面试题
高中生的学习总结自我鉴定
2013/10/26 职场文书
销售主管岗位职责范本
2014/02/14 职场文书
简易离婚协议书范本
2014/10/24 职场文书
2014年绿化工作总结
2014/12/09 职场文书
2015年护士工作总结范文
2015/03/31 职场文书
2015年社区矫正工作总结
2015/04/21 职场文书
如何撰写促销方案?
2019/07/05 职场文书
类和原型的设计模式之复制与委托差异
2022/07/07 Javascript