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

CSDN 2024-08-13 15:05:08 阅读 69

一.rand

1.rand介绍

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

int rand (void);

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

2.使用

头文件是:#include<stdlib.h>

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.h>

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

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

四.生成随机数综合运用

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

2.代码如下:

#include <stdio.h>

#include <stdlib.h>

#include <time.h>

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设备,该设备也可以产生随机数,但不会阻塞,当熵源不足时会使用伪随机数算法来生成数据。

3.单片机内硬件随机发生器产生随机数

      有些单片机有内部硬件随机发生器,可以产生真正的随机数,比如:

STM32F407 自带了硬件随机数发生器(RNG),RNG 处理器是一个以连续模拟噪声为基础的随机数发生器,在主机读数时提供一个 32 位的随机数。

---------------------------------------------------------------------------------------------------------------------------------

推荐一个不错的人工智能学习网站,通俗易懂,内容全面,作为入门科普和学习提升都不错,分享一下给大家:https://www.captainbed.cn/ai

 



声明

本文内容仅代表作者观点,或转载于其他网站,本站不以此文作为商业用途
如有涉及侵权,请联系本站进行删除
转载本站原创文章,请注明来源及作者。