C#实现拼手气红包算法
程序员文章站
2022-03-06 08:28:14
本文实例为大家分享了c#实现拼手气红包算法的具体代码,供大家参考,具体内容如下一、方案1:即开即中,考虑机会均等,减少金额差较大的几率可以每次点击时候,随机产生static double[] getr...
本文实例为大家分享了c#实现拼手气红包算法的具体代码,供大家参考,具体内容如下
一、方案1:即开即中,考虑机会均等,减少金额差较大的几率
可以每次点击时候,随机产生
static double[] getrandommoney(double money, int n) { double[] array = new double[n]; redpackage red = new redpackage() { money = money, count = n }; for (int i = 0; i < n; i++) { array[i] = getrandommoney(red); } return array; } /// <summary> /// 即开即中,考虑机会均等,减少金额差较大的几率 /// 随机产生,额度在0.01和剩余平均值*2之间 /// </summary> /// <returns></returns> static double getrandommoney(redpackage redpackage) { //如果最后一个,返回全部 if (redpackage.count == 1) { redpackage.count--; return math.round(redpackage.money * 100) / 100.00; } //随机生成 random ran = new random(); double min = 0.01; double max = redpackage.money / redpackage.count * 2; double money = ran.nextdouble() * max; money = money <= min ? 0.01 : money; money = convert.toint32(money * 100) / 100.00; redpackage.count--; redpackage.money -= money; return money; } public class redpackage { /// <summary> /// 剩余红包数量 /// </summary> public int count; /// <summary> /// 剩余金额 /// </summary> public double money; }
生成5组随机结果如下:
二、方案2: 一次性拆分红包,不考虑机会平等性
/// <summary> /// 一次性拆分红包,不考虑机会平等性 /// 最小单位1 分 /// </summary> static double[] diviedone(double money, int n) { double min = 0.01; if (money < min) throw new exception("拆分金额不能小于0.01 "); int fen = (int)money * 100; //创建n 个红包数组 int[] array = new int[n]; //每个红包先填充1分 array.fill(array, 1); fen -= n; //第二步,随机分配 random ran = new random(); int i = 0; while (fen > 1) { int f = ran.next(fen); array[i % n] += f; fen -= f; i++; } //最后一分钱,补到第一个数组 if (fen > 0) { array[0] += fen; } return array.select(q => q / 100.0).toarray(); }
生成5组随机结果如下:
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。