1、srand((unsigned)time(NULL))则使用系统定时/计数器的值作为随机种子。
(资料图片)
2、每个种子对应一组根据算法预先生成的随机数,所以,在相同的平台环境下,不同时间产生的随机数会是不同的,相应的,若将srand(unsigned)time(NULL)改为srand(TP)(TP为任一常量),则无论何时运行、运行多少次得到的“随机数”都会是一组固定的序列,因此srand生成的随机数是伪随机数。
3、 库函数中系统提供了两个函数用于产生随机数:srand()和rand()。
4、 原型为: 函数一:int rand(void); 返回一个[0,RAND_MAX]间的随机整数。
5、 函数二:void srand(unsigned seed); 参数seed是rand()的种子,用来初始化rand()的起始值。
6、 但是,要注意的是所谓的“伪随机数”指的并不是假的随机数。
7、其实绝对的随机数只是一种理想状态的随机数,计算机只能生成相对的随机数即伪随机数。
8、计算机生 成的伪随机数既是随机的又是有规律的 —— 一部份遵守一定的规律,一部份则不遵守任何规律。
9、比如“世上没有两片形状完全相同的树叶”,这体现到了事物的特性 —— 差异性;但是每种树的叶子都有近似的形状,这正是事物的共性 —— 规律性。
10、从这个角度讲,我们就可以接受这样的事实了:计算机只能产生伪随机数而不是绝对的随机数。
本文分享完毕,希望对你有所帮助。