C语言中生成随机数的几种方式

2024-06-01 1727阅读

一.rand

C语言中生成随机数的几种方式
(图片来源网络,侵删)

1.rand介绍

C语言提供了一个函数叫rand,这函数是可以生成随机数的,函数原型如下所示:

int rand (void);

rand函数会返回一个伪随机数,这个随机数的范围是在0~RAND_MAX之间,这个RAND_MAX的大小是依赖编译器上实现的,但是大部分编译器上是32767。

2.使用

头文件是:#include

printf("%d\n", rand());

rand()%100+1;//%100的余数是0~99,0~99的数字+1,范围是1~100

如果要生成100~200的随机数,方法如下:

100 + rand()%(200-100+1)

//余数的范围是0~100,加100后就是100~200

如果要生成a~b的随机数,方法如下:

a + rand()%(b-a+1)

3.说明:

rand函数是对一个叫“种子”的基准值进行运算生成的随机数。

每次运行程序产生的随机数序列是?样的,那是因为rand函数生成随机数的默认种子是1。如果要生成不同的随机数,就要让种子是变化的。

二.srand

1.srand介绍

C语言中还提供了一个函数叫srand用来初始化随机数的生成器的,srand的原型如下:

void srand (unsigned int seed);

程序中在调用rand函数之前先调用srand函数,通过srand函数的参数seed来设置rand函数生成随机数的时候的种子,只要种子在变化,

每次生成的随机数序列也就变化起来了。那也就是说给srand的种子是如果是随机的,rand就能生成随机数;在生成随机数的时候又需要一个随机数。

三.time

1.time函数介绍

在程序中我们一般是使用程序运行的时间作为种子,因为时间时刻在发生变化的。

在C语言中有一个函数叫time,就可以获得这个时间,time函数原型如下:

time_t time (time_t* timer);

time函数会返回当前的日历时间,其实返回的是1970年1月1日0时0分0秒到现在程序运行时间之间的差值,单位是秒。返回的类型是time_t类型的,time_t类型本质上其实就是32位或者64位的整型类型。

time函数的参数timer如果是非NULL的指针的话,函数也会将这个返回的差值放在timer指向的内存中带回去。

如果timer是NULL,就只返回这个时间的差值。time函数返回的这个时间差也被叫做:时间戳。

2.测试代码

头文件:#include

如果只是让time函数返回时间戳,我们就可以这样写:

time(NULL);//调用time函数返回时间戳

四.生成随机数综合运用

1.用time函数返回值做为种子,然后再生成随机数

2.代码如下:

#include

#include

#include

int main()

{

    // 设置种子为当前时间  

    srand((unsigned int)time(NULL));  

    // 生成并打印一个随机数(0到RAND_MAX之间)  

    int random_number = rand();  

    printf("随机数:%d\n", random_number);  

  

    // 生成并打印一个在指定范围内的随机数(例如1到100之间)  

    int min = 1, max = 100;  

    int range = max - min + 1;  

    int random_number = min + rand() % range;  

    printf("1到100之间的随机数:%d\n", random_number_in_range);

return 0;

}

五.产生真随机数的两种方式

1.openssl的实现方式,基本步骤如下:

首先会获取系统提供的真随机数源,源产生的数据是由系统硬件或操作系统的事件(例如用户的鼠标移动、键盘输入、硬件噪声等)产生的,具有高度的随机性。

这些数据放到熵池中,然后使用一个伪随机数生成器(通常是一个加密安全的伪随机数生成器)来从熵池中生成更多的随机数据。


2.linux下产生随机数的方法

/dev/random设备是Linux系统中的一个随机数发生器,它可以产生高质量的随机数,这些随机数可以用于加密、认证等安全性要求较高的场景。

注意:

由于/dev/random设备仅依赖于系统环境中的熵源(如硬件噪声),因此在系统运行初期可能无法立即生成足够的随机数,此时读取操作会阻塞。

为了避免长时间阻塞,可以使用/dev/urandom设备,该设备也可以产生随机数,但不会阻塞,当熵源不足时会使用伪随机数算法来生成数据。

 

VPS购买请点击我

免责声明:我们致力于保护作者版权,注重分享,被刊用文章因无法核实真实出处,未能及时与作者取得联系,或有版权异议的,请联系管理员,我们会立即处理! 部分文章是来自自研大数据AI进行生成,内容摘自(百度百科,百度知道,头条百科,中国民法典,刑法,牛津词典,新华词典,汉语词典,国家院校,科普平台)等数据,内容仅供学习参考,不准确地方联系删除处理! 图片声明:本站部分配图来自人工智能系统AI生成,觅知网授权图片,PxHere摄影无版权图库和百度,360,搜狗等多加搜索引擎自动关键词搜索配图,如有侵权的图片,请第一时间联系我们,邮箱:ciyunidc@ciyunshuju.com。本站只作为美观性配图使用,无任何非法侵犯第三方意图,一切解释权归图片著作权方,本站不承担任何责任。如有恶意碰瓷者,必当奉陪到底严惩不贷!

目录[+]