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

使用一个公式实现简单的离散模型来把数值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();
        }
    }


你可能感兴趣的:(使用简单的离散模型来实现把数值N分割成M份随机数。)