rand()和srand()关系很简单——一看就明白(通过一个可移植的源码)
2014-04-01 12:55
441 查看
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的代码演示
#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的代码演示
相关文章推荐
- 通过一个模拟程序让你明白ASP.NET MVC是如何运行的
- 通过对一个病毒源码的分析,了解VBS脚本语言的应用
- 自己实现了一个LinkedList对照源码一看,呵呵呵
- mybatis源码解析 - 通过一个简单查询例子分析流程
- Linux I2C 几个结构体间的关系以及对于一个I2C设备的移植,我们需要做些什么工作
- 通过一个模拟程序让你明白WCF大致的执行流程
- 让你一看就明白什么是单列模式(和静态静态工厂模式)--java版本_源码下载
- 通过创建一个位图的XY Chart来学习Android绘图类Rect,Paint,Bitmap,Canvas(附源码)
- 通过V8源码看一个关于JS数组排序的诡异问题
- 写了一个很简单API串口编程的源代码,调试通过,希望给需要的人有所帮助
- 通过SVN导入两个项目(从java移植到andorid)时,一个android,一个普通java项目时可能遇到的两个问题
- 让你一看就明白什么是聚合-java版本_源码下载
- 通过发送广播来向桌面添加一个快捷方式(附源码)
- 通过一个模拟程序让你明白ASP.NET MVC是如何运行的
- android开发步步为营之79:通过源码分析Looper,Handler,MessageQueue之间的关系
- 让你一看就明白什么是单列模式(和静态静态工厂模式)--java版本_源码下载
- mybatis源码解析 - 通过一个简单查询例子分析流程
- 如何把一个DataTable中的某列通过表关系加到另外一个DataTable中
- 实现一个猜数字的小游戏,rand和srand的使用
- 通过 nodeclub 项目源码来讲解如何做一个 nodejs + express + mongodb 项目