C#實現微信紅包功能。本站提示廣大學習愛好者:(C#實現微信紅包功能)文章只能為提供參考,不一定能成為您想要的結果。以下是C#實現微信紅包功能正文
作者:WuLex
這篇文章主要介紹了C#實現微信紅包功能,使用正態分布計算紅包金額,具有一定的參考價值,感興趣的小伙伴們可以參考一下本文實例為大家分享了C#仿微信紅包功能的具體代碼,供大家參考,具體內容如下
Program.cs代碼:
class Program { static void Main(string[] args) { //初始化要發起的紅包基礎數據 double total = 100; int num = 50; double min = 0.01; string temp; bool flag = false; Console.WriteLine(string.Format("是否需要自定義紅包金額和數量(默認{0}元/{1}人)Y/N:", total, num)); temp = Console.ReadLine(); if (temp.Trim().ToLower().Equals("y") || temp.Trim().ToLower().Equals("yes")) { Console.WriteLine("請輸入你要發起的紅包金額:"); do { temp = Console.ReadLine(); flag = double.TryParse(temp, out total); if (!flag) { Console.WriteLine("金額必須為整數或小數,請重新輸入:"); } } while (!flag); Console.WriteLine("請輸入你要發起的紅包個數:"); do { temp = Console.ReadLine(); flag = int.TryParse(temp, out num); if (!flag) { Console.WriteLine("紅包個數必須為整數,請重新輸入:"); } } while (!flag); } total -= min * num; if (total < 0) { Console.WriteLine("抱歉,你的金額不足!"); return; } //產生正態分布的隨機紅包金額,並計算相關的金額和數量保證數據的准確性 double average = total / num; double variance = 1; Random u1 = new Random(); Random u2 = new Random(); double[] nums = new double[num]; for (int i = 0; i < num; i++) { double? result = total; if (i < num - 1 && total > 0) { do { result = Round((double)Normal(u1.NextDouble(), u2.NextDouble(), average, variance), 2); } while (result == null || result < 0); if (total > result) { total = (double)Round((total - (double)result), 2); } else { result = total; total = 0; } } else if (i == num - 1) { total = 0; } nums[i] = Math.Round(min + (double)result, 2); //浮點運算問題,這裡需要四捨五入數據才正確 Console.WriteLine(string.Format("第{0}個紅包金額:{1}", i + 1, (min + result))); Console.WriteLine("剩余金額:" + ((i != num - 1 && total == 0) ? min * (num - i - 1) : total + (min * (num - i - 1)))); } Console.WriteLine("最大金額:" + nums.Max()); Console.WriteLine("最小金額:" + nums.Min()); Console.WriteLine("總額:" + Round(nums.Sum(), 2)); Console.WriteLine("初始方差:" + variance); Console.WriteLine("結果方差:" + Variance(nums)); Console.WriteLine("按任意鍵退出!"); Console.ReadKey(); } /// <summary> /// 產生符合正態分布的隨機數 /// </summary> /// <param name="u1">正態分布第一個隨機數</param> /// <param name="u2">正態分布第二個隨機數</param> /// <param name="averageValue">正態期望(平均值)</param> /// <param name="variance">正態標准差(Math.Sqrt(方差))</param> /// <returns></returns> public static double? Normal(double u1, double u2, double averageValue, double variance) { double? result = null; try { result = averageValue + Math.Sqrt(variance) * Math.Sqrt((-2) * Math.Log(u1)) * Math.Sin(2 * Math.PI * u2); } catch (Exception) { result = null; } return result; } /// <summary> /// 求一組數據的方差 /// </summary> /// <param name="list">要求的數組</param> /// <returns></returns> public static double Variance(double[] nums) { double average = nums.Sum() / nums.Length; double sum = 0; double variance = 0; foreach (double num in nums) { sum += Math.Pow((num - average), 2); } variance = sum / nums.Length; return variance; } /// <summary> /// 截取小數指定小數位,且不四捨五入 /// </summary> /// <param name="originNum">要截取的小數</param> /// <param name="lastNum">截取小數後位數</param> /// <returns></returns> public static double? Round(double originNum, int lastNum) { double? result = null; int index = originNum.ToString().IndexOf('.'); if (index != -1) { string temp = originNum.ToString(); result = Convert.ToDouble(temp.Substring(0, index + 1) + temp.Substring(index + 1, Math.Min(temp.Length - index - 1, lastNum))); } if (result == 0) { result = null; } else if (index == -1) { result = originNum; } return result; } }
運行結果:
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持。