C#實現拼手氣紅包演算法
阿新 • • 發佈:2020-09-14
本文例項為大家分享了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組隨機結果如下:
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支援我們。