1 函数rand和srand实现及描述
#include <stdlib.h>
//供rand()使用的种子数,初值为1
unsigned long int next = 1;
/*
* 描述:函数rand() 用于生成介于 0和RAND_MAX之间的伪随机整数序列
* 其中RAND_MAX是在头文件<stdlib.h> 中定义的符号常 量, RAND_MAX的取值至少为32767
* 输入:无
* 输出:返回取值在0~RAND_MAX之间的伪随机数
*/
int rand(void)
{
next = next *1103515245 +12345;
return (unsigned int)(next/65536) % (RAND_MAX);
}
/*
* 描述: srand函数用参数seed作为生成伪随机数序列的函数rand的种子
* 输入:种子seed
* 输出:无
*/
void srand(unsigned int seed)
{
next = seed;
}
2 函数说明
(1) rand()生成的是伪随机序列:原因在于对于相同的种子只能生成相同的输出序列(函数呀)。
(2) 在不使用srand()情况下,next==1,也就是种子为1。当然生成的伪随机序列也相同。
注意:相同的种子生成相同的序列,因此序列具有可重现性。一个种子对应一个序列,因此可以使用不同的种子生成不同的序列。
3 种子选择
由于生成不同序列需要不同的种子,所以一般使用srand(getpid())和srand(time(NULL))生成种子。
4 生成不同的伪随机数
(1) 生成[0, 1)的随机浮点数的方法:
((double) rand( ) / (RAND_MAX + 1.0));
(2) 生成[0, n) = n*[0, 1)的随机浮点数的方法:
(double) (n * (rand( ) / (RAND_MAX + 1.0)));
5 生成0..100的代码演示