我正在考虑生成 1 到 500 万之间的随机数。这个过程不必很快(尽管如果快的话就好了),但它必须尽可能随机(我知道没有什么是随机的)。我有多种种子数据源。
我不确定是否.NET http://en.wikipedia.org/wiki/.NET_Framework Random https://msdn.microsoft.com/en-us/library/system.random%28v=vs.110%29.aspx类对此已经足够好了。
这将用于选择中奖彩票。
The System.Random http://msdn.microsoft.com/en-us/library/system.random.aspx类可能已经足够好了:
伪随机数是从有限的一组数字中以相等的概率选择的。所选择的数字并不是完全随机的,因为使用了确定的数学算法来选择它们,但对于实际目的来说,它们是足够随机的。 Random 类的当前实现基于 Donald E. Knuth 的减法随机数生成器算法。欲了解更多信息,请参阅 D. E. Knuth。 “计算机编程艺术,第 2 卷:半数值算法”。 Addison-Wesley,雷丁,马萨诸塞州,第二版,1981 年。
您唯一需要注意的是不要经常重复使用相同的种子:
如果重复使用相同的种子,则会生成相同的数字序列。生成不同序列的一种方法是使种子值与时间相关,从而为每个新的 Random 实例生成不同的序列。
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)