新技能get√丨抢了那么多红包,你知道算法是怎么实现的吗

2023-10-24 08:50

本文主要是介绍新技能get√丨抢了那么多红包,你知道算法是怎么实现的吗,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

没红包可抢的日子真是太难熬了


好在元宵节到了!


微信官方统计,仅除夕到初五,微信总计收发红包次数多达321亿次,上百亿个微信红包散落在了万家灯火的欢声笑语之中,这其中,就“一次能抢到多少钱”的这个问题,发生了这样一段“从线上到线下”的对话:

妈妈:老盯着手机干什么?

儿子:抢红包

妈妈:能抢多少?

儿子:看手法,有时候白忙,有时候几分钱到一两块

妈妈:我给你10块,你去给我把锅刷了…



看到这个段子,玩营销的在琢磨商机,做设计的在审视红包配色,做产品的在考虑互动机制,而我们超爱思考的程序员们,早已就红包算法的n种实现方法讨论得热火朝天……


本周起,小卓每周一与各位IT大侠讨论各种有趣的技术问题,今天,咱们先聊聊如火如荼的“红包算法”。


MONDAY:新技能get

微信红包算法



首先,为了采集样本,顺带感谢毕业多年来一直孜孜不倦嘘寒问暖的大学同学们,小卓在同学群里发了个红包:设定红包总额为10元,支持28个人随机领取(礼轻情意重啊)。

不出所料,大家一边骂我抠门,一边抢抢抢。


在挨骂的同时,小卓没有忘记发红包的初衷,开始兢兢业业地采集样本:

A领取了0.26元

B领取了0.29元

C领取了0.02元

D领取了0.56元

E领取了0.64元

……

有趣的现象出现了:随机分配,人人有份,又各自不同,微信是采用什么样的算法做到的?

简单百度了下,目前尚未有官方的说明,仅仅在知乎里有一个较为热门的讨论《微信红包的随机算法是怎样实现的?》(https://www.zhihu.com/question/22625187 )不过他们讨论的太过于深入,有掉坑之嫌,于是自己动手。


按照红包的逻辑,红包算法需要满足以下几点要求:

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

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

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

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


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

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

N=1

则红包金额=X元; 

N=2,

为保证第二个红包可以正常发出,

红包1=0.01至9.99之间的某个随机数,

红包2=10-第一个红包金额; 

N=3,

红包1=0.01至9.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 元


就这样,实现了一种红包算法。


什么?你想到了更好的?赶快留言啊,说来听听!

算法来自:http://blog.cqcoder.com/微信红包的算法实现探讨/



这篇关于新技能get√丨抢了那么多红包,你知道算法是怎么实现的吗的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/274067

相关文章

Oracle查询优化之高效实现仅查询前10条记录的方法与实践

《Oracle查询优化之高效实现仅查询前10条记录的方法与实践》:本文主要介绍Oracle查询优化之高效实现仅查询前10条记录的相关资料,包括使用ROWNUM、ROW_NUMBER()函数、FET... 目录1. 使用 ROWNUM 查询2. 使用 ROW_NUMBER() 函数3. 使用 FETCH FI

Python脚本实现自动删除C盘临时文件夹

《Python脚本实现自动删除C盘临时文件夹》在日常使用电脑的过程中,临时文件夹往往会积累大量的无用数据,占用宝贵的磁盘空间,下面我们就来看看Python如何通过脚本实现自动删除C盘临时文件夹吧... 目录一、准备工作二、python脚本编写三、脚本解析四、运行脚本五、案例演示六、注意事项七、总结在日常使用

Java实现Excel与HTML互转

《Java实现Excel与HTML互转》Excel是一种电子表格格式,而HTM则是一种用于创建网页的标记语言,虽然两者在用途上存在差异,但有时我们需要将数据从一种格式转换为另一种格式,下面我们就来看看... Excel是一种电子表格格式,广泛用于数据处理和分析,而HTM则是一种用于创建网页的标记语言。虽然两

Java中Springboot集成Kafka实现消息发送和接收功能

《Java中Springboot集成Kafka实现消息发送和接收功能》Kafka是一个高吞吐量的分布式发布-订阅消息系统,主要用于处理大规模数据流,它由生产者、消费者、主题、分区和代理等组件构成,Ka... 目录一、Kafka 简介二、Kafka 功能三、POM依赖四、配置文件五、生产者六、消费者一、Kaf

使用Python实现在Word中添加或删除超链接

《使用Python实现在Word中添加或删除超链接》在Word文档中,超链接是一种将文本或图像连接到其他文档、网页或同一文档中不同部分的功能,本文将为大家介绍一下Python如何实现在Word中添加或... 在Word文档中,超链接是一种将文本或图像连接到其他文档、网页或同一文档中不同部分的功能。通过添加超

windos server2022里的DFS配置的实现

《windosserver2022里的DFS配置的实现》DFS是WindowsServer操作系统提供的一种功能,用于在多台服务器上集中管理共享文件夹和文件的分布式存储解决方案,本文就来介绍一下wi... 目录什么是DFS?优势:应用场景:DFS配置步骤什么是DFS?DFS指的是分布式文件系统(Distr

NFS实现多服务器文件的共享的方法步骤

《NFS实现多服务器文件的共享的方法步骤》NFS允许网络中的计算机之间共享资源,客户端可以透明地读写远端NFS服务器上的文件,本文就来介绍一下NFS实现多服务器文件的共享的方法步骤,感兴趣的可以了解一... 目录一、简介二、部署1、准备1、服务端和客户端:安装nfs-utils2、服务端:创建共享目录3、服

C#使用yield关键字实现提升迭代性能与效率

《C#使用yield关键字实现提升迭代性能与效率》yield关键字在C#中简化了数据迭代的方式,实现了按需生成数据,自动维护迭代状态,本文主要来聊聊如何使用yield关键字实现提升迭代性能与效率,感兴... 目录前言传统迭代和yield迭代方式对比yield延迟加载按需获取数据yield break显式示迭

Python实现高效地读写大型文件

《Python实现高效地读写大型文件》Python如何读写的是大型文件,有没有什么方法来提高效率呢,这篇文章就来和大家聊聊如何在Python中高效地读写大型文件,需要的可以了解下... 目录一、逐行读取大型文件二、分块读取大型文件三、使用 mmap 模块进行内存映射文件操作(适用于大文件)四、使用 pand

python实现pdf转word和excel的示例代码

《python实现pdf转word和excel的示例代码》本文主要介绍了python实现pdf转word和excel的示例代码,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价... 目录一、引言二、python编程1,PDF转Word2,PDF转Excel三、前端页面效果展示总结一