伪随机数
使用一个确定性的算法计算出来的似乎是随机的数序
计算机的随机数都是由
伪随机数(小M多项式序列
)生成的,其中产生每个小序列都有一个初始值,即随机种子.(注意: 小M多项式
序列的周期是65535,即每次利用一个随机种子生成的随机数的周期是65535,当你取得65535个随机数后它们又重复出现了.)
rand
rand()内部实现是用线性同余法做的,不是真随机数,周期长,故可看成随机.
rand()返回一随即数值的范围,在0至RAND_MAX间. 0~RAND_MAX,每个数字被选中的几率相同
用户未设定随机数种子时,系统默认的随机数种子为1
rand()产生的是伪随机数字,每次执行时是相同的.因为随机种子一样
srand
初始化随机数发生器
srand()用来设置rand()产生随机数时的随机数种子
当前时钟作为随机数种子
一定范围随机数
[a,b) 之间随机整数 (rand() % (b - a)) + a;
[a,b] 之间随机整数 (rand() % (b- a + 1)) +a;
(a.b] 之间随机整数 (rand() % (b - a )) + a +1;
通用公式: a + rand() % n;