在求随机数时我们会用到rand与srand函数
rand与srand有什么区别呢?
首先我们应该先设置头文件#include<stdlib.h>
然后我们直接输入rand()
运行后会发现每次结果都是相同的,原因是rand()函数生成的是伪随机数,而非真随机数。他只是计算机通过算法得到的一个数。
那我们如何得到一个真随机数呢?
这里我们需要采用srand()函数
void srand (unsigned int seed);
在srand()函数中,通过srand()函数来初始化随机种子,这个种子会对应一个随机数,如果使用相同的种子后面的 rand() 函数会出现一样的随机数,如: srand(1); 所以我们通常会使用time()函数来返回自 1970 年 1 月 1 日 到现在当前的时间,而我们当前的时间又是每秒都在变动的,就可以产生不同的随机种子,就有了不同的随机数。
那这里就会产生疑问,初始化随机种子在随着时间改变而改变,那所生成的随机数是否也会一点一点变化?
这里我们需要了解,数字存储在电脑中并不是按照数字大小顺序,而是打乱的数据,通过rand()一个一个输出的。
但是如果我们将srand()也放到循环中去只要运行够快,我们可以发现获得的随机数是没有变化的,我认为这是因为在数字存储在电脑中时是打乱的,但是也是以好几个数放在一起的数组来存储的,若是把srand()放到循环里,时间没有变化,依旧是那个数组,也依旧会输出第一个数,所以没有变化。