概述
背景:之前过年亲戚人都在抢红包,都想抢第一个,说是越早抢越大。其实这肯定是不正确的,微信在你发红包的时候应该已经生成所有的红包了,所以说你无论第几个抢,按说应该都一样,除非微信做了一些处理,比如说越早抢红包越可能手气最佳,过完年回来上班,突然想起了微信红包,就在想微信红包生成的策略。
20块钱10个红包,人均2块钱。因为理论上红包的金额应该在2块钱左右,而且越大概率越小,感觉这个很像正态分布函数,所以感觉微信红包属于截尾正态分布。手气最佳一般在2倍-3倍左右。
类似于这种(网上找的图):
所有红包在发送者发红包的时候都已经生成好了,领红包只是领生成的红包而已,点击别人发的红包,只会计算你点击的那一时刻还有没有红包,如果没有了,你就只能查看details了,所以说打开的时候出现的那个拆字相当于一个令牌,你可以凭借这个令牌去领红包,当然这个令牌在领红包的时候也有可能红包被领完了,所以你也就回去看details了,如果领到了就会告诉你领了多少钱。
每一次从红包金额池里随机出的金额应该是当时剩余总人数的均值,比如第一个人抽应该基于2的正态分布,如果他抽了4块钱,那么随机第二个红包的时候自然是基于16/9的正态分布,以此往后推,抽到倒数第一个就不用抽了,直接把剩下的都分了就行。而且因为红包最小是0.01嘛,所以每一次抽奖的时候都得留够足够的钱来用于发放剩下的红包,随意每一次随机都得判断。而且我做了一个限额倍数,因为随机出来的数字很可能在均值偏下的地方,多个累积起来,很可能就会造成最后一个红包过大的可能,所以我做了调整,当最后一个红包大于一定的倍数的时候,需要重新抽。另外,按这样抽奖,第一个人的均值应该最大,所以我在最后对生成的红包打乱了顺序。
随机生成红包的代码,做了一些简单的封装。
若Y~N(a,b^2) (b>0),则X=(Y-a)/b~(0,1)
package com.galaxy.fym.algorithm.maxsublist;
import java.math.BigDecimal;
import java.util.*;
/**
* Created by fengyiming on 2017/2/17.
*
* @author fengyiming
* 随机产生红包:金额正太分布
*
* 如果非标准正态分布X~N(μ,σ^2),那么关于X的一个一次函数 (X-μ)/σ ,就一定是服从标准正态分布N(0,1)。
* 举个具体的例子,一个量X,是非标准正态分布,期望是10,方差是5^2(即X~N(10,5^2));那么对于X的线性函数Y=(X-10)/5,Y就是服从标准正态分布的Y~N(0,1)。
*/
public class RedPacket {
private static Random random = new Random();
private static BigDecimal MIN_VALUE = new BigDecimal("0.01");
private static boolean isMin = false;
/**
* 生成红包
*
* @param amountValue 红包总金额
* @param sizeValue 红包大小
* @param maxMutValue 剩余红包限定倍数
* @param sigmaValue 标准差倍数
* @return
*/
public static List<BigDecimal> getAllHotPacket(
最后
以上就是超级火龙果为你收集整理的微信红包算法研究的全部内容,希望文章能够帮你解决微信红包算法研究所遇到的程序开发问题。
如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。
发表评论 取消回复