使用简单的离散模型来实现把数值N分割成M份随机数。

mac2024-05-10  29

使用一个公式实现简单的离散模型来把数值N分割成M份随机数。

和微信里的抢红包的模型一样。把一个数分割成M份,随机产生每一份的值,总和相加等于N,精确小数点后两位。

具体看代码:

class Program { static void Main(string[] args) { Console.WriteLine("使用离散模型实现把数值N分割成M份随机数。\n"); Console.Write("请输入要分割的数值:"); double num = Convert.ToDouble(Console.ReadLine()); //输入数值N(N是需要分割的数); Console.Write("请输入分割的个数:"); int s_num = Convert.ToInt32(Console.ReadLine()); //输入数值M(M是需要分割的个数) double min = 0.01; //初始化定义一个“最小值” Random random = new Random(); //创建随机数对象Random for (int i = 1; i < s_num; i++) { //设置“循环” double a = (num - (s_num - i) * min) / (s_num - i); //通过公式模拟数学中的离散模型 double b = (double)random.Next((int)((a - min) * 100)) / 100 + min; //根据离散模型得到每个随机的数值; num = num - b; //替换num的值 Console.WriteLine("第" + i + "个值:{0:F2}", b); //输出结果 } Console.WriteLine("第" + bagsnum + "个值:{0:F2}",num); //输出结果(最后一个值) Console.ReadLine(); } }
最新回复(0)