c++ time函数_C++生成随机数rand/srand函数

本文介绍了C++中用于生成随机数的`rand()`和`srand()`函数。`rand()`返回0到RAND_MAX之间的整数,而`srand()`通过设置种子(常用`time(NULL)`确保每次运行时的随机性)来改变`rand()`的序列。通过取余运算和加1,可以将随机数限制在特定范围内。在C++11之后,还有更多高级的随机数生成选项。
摘要由CSDN通过智能技术生成
35c03ae6c9f05330528c66295285bdee.png

Matlab内置了五种随机函数:

  • rand:生成在(0, 1)之间均匀分布的随机数
  • randn:生成均值为0,方差为1的标准正态分布的随机数
  • randi(imax):生成在[1, imax] 均匀分布的伪随机整数
  • randsrc(m, n, [alphabet; prob]):生成一个m-by-n的矩阵,矩阵的元素从alphabet里抽取,alphabet每个元素被抽中的概率由prob指定。
  • randperm(n):生成一个1到n的随机顺序。

Matlab内置的五种随机函数

而C++中要生成随机数,通常需要使用rand()和srand()两个函数。

对于C++ 11之前的随机数生成,只需rand/srand这两函数即可,C++11之后提供了更多的选择和东西,这里暂且不表。

1、rand函数

int rand(void);

rand()函数返回一个 0 ~ RAND_MAX 之间的整数。RAND_MAX 是一个定义在 的常数。

该函数返回的数字实际上是用算法生成的,实际上并不是随机的。它是根据种子生成的,根据不同的种子产生不同的随机序列。系统默认的种子是1,所以说每次使用的随机序列都是固定的。

比如下面这段代码:

#include using namespace std;int main(){    cout << "RAND_MAD: " << RAND_MAX << endl;    int x = rand();    cout << "x: " << x << endl;      return 0;}

运行结果如下图所示,可以看出,每次运行的结果,x 的值都是固定的。

0cebb29ef1dae07a49fbf25c6e1cb40f.png

2、srand函数

要想使每次运行时变量 x 的值都不同,就必须使它的种子随机,这时就需要用到srand函数。

void srand(unsigned int seed);

srand()函数就是用来设置rand()函数的种子的。根据不同的输入参数可以产生不同的种子。通常使用time函数作为srand函数的输入参数。

time(NULL);

time函数会返回1970年1月1日至今所经历的时间(以秒为单位)。

C语言和时间有关的函数示例

C函数time和clock的计时区别

在使用 rand() 函数之前,srand() 函数要先被调用,并且在整个程序中只需被调用一次。代码如下:

#include using namespace std;int main(){    srand(time(0));    int x = rand();    cout << "x: " << x << endl;      return 0;}

运行结果如下:

e7a593b1c622eafb85977afe107b1539.png

注意:time函数会返回的是1970年1月1日至今所经历的时间(以秒为单位),若你手速足够快,在1s内能够执行多次,即time函数返回的值相同,x 的值也会相同。

21bea4bb899850b4af9c10936ad69685.png

3、指定随机数的范围

在实际应用中,通常需要要将随机数的范围限制在 1 到某个值 max 之间,则可以使用以下公式:

int var = rand() % max + 1;

求余数运算符(%)可以获得整除之后的余数。如当 max 为 6 时,余数将是 0 〜 5,给余数加 1 即可转换为 1 ~ 6。

#include using namespace std;int main(){    srand(time(0));    int x = rand() % 6 + 1;    cout << "x: " << x << endl;      return 0;}

运行结果如下:

44e8884bbd556d96c9a550b0eb51fcbd.png

PS:计算机是一个可预测的系统,因此不可能通过算法来产生真正的随机数。在计算机中,所谓的随机数通常都是伪随机数,即通过随机算法计算出来的,可以被近似看作随机数的数值。

常见的随机数算法有线性同余法(Linear Congruential Generator)、梅森旋转法(Mersenne twister)等。

796ecbb272f16cae404bfe0d0538b349.png
  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值