微信群红包算法
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了微信群红包算法,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含2106字,纯文字阅读大概需要4分钟。
内容图文
![微信群红包算法](/upload/InfoBanner/zyjiaocheng/1221/e9e9db3da14343d3b1929b5c63471572.jpg)
今天是春节的最后一天上班,没什么事情,正好群里面的同学再讨论群红包的算法。
特写了个算法。大致思路是找发过的红包,寻找它的随机震动坡度。
下面来看看算法吧:
#coding=gbk import random import sys #print random.randint(0, 99) #print "====", random.uniform(0, 0.99) def calRandomValue(min, max, total, num): print min, max, total, num total = float(total) num = int(num) min = 0.01 if(num < 1): return if num == 1: print "第%d个人拿到红包数为:%.2f" %(num, total) return i = 1 total_money = total #rtotal = (total*100 - min*num*100)/100 while( i < num ): max = total_money - min*(num- i) k = int((num-i)/2) if num -i <= 2: k = num -i max = max/k monney = random.randint(int(min*100), int(max*100)) monney = float(monney)/100 total_money = total_money - monney print "第%d个人拿到红包数为:%.2f, 余额为: %.2f" %(i, monney, total_money) i += 1 print "第%d个人拿到红包数为:%.2f, 余额为: %.2f" %(i, total_money, 0.0) if __name__ == "__main__": min = sys.argv[1] max = sys.argv[2] total = sys.argv[3] num = sys.argv[4] calRandomValue(min, max, total, num)
执行:
python 2.py 0.01 10 20 30
0.01 10 20 30
第1个人拿到红包数为:0.42, 余额为: 19.58
第2个人拿到红包数为:0.12, 余额为: 19.46
第3个人拿到红包数为:0.24, 余额为: 19.22
第4个人拿到红包数为:1.10, 余额为: 18.12
第5个人拿到红包数为:1.45, 余额为: 16.67
第6个人拿到红包数为:0.21, 余额为: 16.46
第7个人拿到红包数为:0.34, 余额为: 16.12
第8个人拿到红包数为:0.16, 余额为: 15.96
第9个人拿到红包数为:1.38, 余额为: 14.58
第10个人拿到红包数为:0.86, 余额为: 13.72
第11个人拿到红包数为:1.18, 余额为: 12.54
第12个人拿到红包数为:0.93, 余额为: 11.61
第13个人拿到红包数为:0.70, 余额为: 10.91
第14个人拿到红包数为:0.60, 余额为: 10.31
第15个人拿到红包数为:0.03, 余额为: 10.28
第16个人拿到红包数为:0.61, 余额为: 9.67
第17个人拿到红包数为:1.37, 余额为: 8.30
第18个人拿到红包数为:0.67, 余额为: 7.63
第19个人拿到红包数为:0.28, 余额为: 7.35
第20个人拿到红包数为:0.96, 余额为: 6.39
第21个人拿到红包数为:1.30, 余额为: 5.09
第22个人拿到红包数为:1.08, 余额为: 4.01
第23个人拿到红包数为:1.12, 余额为: 2.89
第24个人拿到红包数为:0.75, 余额为: 2.14
第25个人拿到红包数为:0.64, 余额为: 1.50
第26个人拿到红包数为:0.37, 余额为: 1.13
第27个人拿到红包数为:0.01, 余额为: 1.12
第28个人拿到红包数为:0.26, 余额为: 0.86
第29个人拿到红包数为:0.31, 余额为: 0.55
第30个人拿到红包数为:0.55, 余额为: 0.00
python 2.py 0.01 10 20 2
0.01 10 20 2
第1个人拿到红包数为:1.62, 余额为: 18.38
第2个人拿到红包数为:18.38, 余额为: 0.00
python 2.py 0.01 10 20 3
0.01 10 20 3
第1个人拿到红包数为:4.58, 余额为: 15.42
第2个人拿到红包数为:11.22, 余额为: 4.20
第3个人拿到红包数为:4.20, 余额为: 0.00
原文:http://blog.csdn.net/hhh3h/article/details/43866377
内容总结
以上是互联网集市为您收集整理的微信群红包算法全部内容,希望文章能够帮你解决微信群红包算法所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。