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