当前位置:网站首页>如何生成随机数+原理详细分析
如何生成随机数+原理详细分析
2022-08-02 16:52:00 【51CTO】
说到如何生成一个随机数,可能当你百度后会看到这样一段代码。
那么一个随机数到底是如何生成的呢?我相信善于探索的你一定想知道这其中的原理,那么话不多说,进入正题把!
一个随机数到底是如何生成的:
说到生成随机数我们都知道要用到一个rand函数,那么这个函数究竟是如何运用的呢,我们可以打开MSDN看看这个函数的用法

这里的第一句说到rand函数会返回一个从0到RAND_MAX的整型,那么RAND_MAX的值是多少呢,我们可以将它复制到编译器中然后选中它右击鼠标点击转到定义,就可以看到这句话

其实RAND_MAX的值也就是0x7fff,转换为十进制也就是32767,所以说rand函数可以随机生成一个0到32767的整型,当你在编译器中尝试时,你会看到

当你天真的以为你已经成功的可以生成随机数的时候,你会发现当年再次运行该代码时,它生成的还是这些随机数,也就是第一次运行代码时代码生成了随机数,但是第二次运行时会生成相同的随机数。
这时我们应该想起对rand函数的描述中还有第二句话:在调用rand函数之前,我们要使用srand函数设置生成随机数的起点。我们又在MSDN中查查srand函数:

我们可以看到srand函数的参数是一个无符号整型并且无返回值,那么这时我们可以来测试一下,就随便给一个无符号整型传给srand函数

但是当我们再次执行程序时照样还是这些随机数,当我们把传入srand函数的改变时,发现所给随机数便改变了:

所以我们只要在每次执行程序的时候给srand函数传入一个与上一次不同的数即可,但是我们就是要生成一个随机数,现在又需要一个随机数,这不成死循环了吗?
这时我们想到在电脑上有一个东西是时刻在发生着变化的,那就是时间,这时我们需要介绍一个概念,那就是时间戳。
时间戳: 当前时间与计算机起始时间的差值,单位是秒。
计算机的起始时间:1970-01-01 08:00:00

每一秒的时间戳都不一样,所以我们只要把时间戳传入srand函数即可,这时我们就需要用到time函数,因为time函数的返回值就是时间戳。

这里我们可以看到time函数的参数是time_t型指针,返回值是time_t型,这里的time_t我们也可以把它放到编译器中右击鼠标,点击转到定义:

这里我们可以看到,其实time_t就是int型被typedef重定义了(也就是起了个别名)而已。
而我们也不需要向time函数传入什么指针,于是我们就向time函数传入一个空指针( NULL)即可,也就是time( NULL),但是srand函数的参数是unsigned int型,所以我们如果要将time函数的返回值传入srand函数,那么我们就需要将time函数的返回值强制性转化会unsigned int型,也就是( unsigned int )time( NULL),所以我们最终将代码写为:

这样,每次运行代码时所得到的就是真正意义上的随机数了。
如何生成规定位数的随机数:
生成两位随机数:

我们只需要将所得随机数对90取余数,那么我们得到的数就是0-89的数字,这时再加上10便是10-99的数字了。
生成三位随机数:

道理与生成两位随机数相同我就不再阐述了。
边栏推荐
- JS数组删除其中一个元素
- 在idea中创建web项目_idea部署web项目
- Flink SQL搭建实时数仓DWD层
- Oracle 11 g rac finished patch, dbca new patches of SQL database also needs to perform?
- VMware启动报错:另一个程序已锁定文件的一部分,进程无法访问(删除最近的.lck文件夹)
- 1.NVIDIA Deepstream开发指南中文版--欢迎使用 DeepStream 文档
- navicat创建连接 2002-can‘t connect to server on localhost(10061)且mysql服务已启动问题
- 融云「 IM 进阶实战高手课」系列直播上线
- 【genius_platform软件平台开发】第七十五讲:YUY2转RGB24实现源码
- 电烙铁的基础知识
猜你喜欢
随机推荐
2022年PMP考试应该注意些什么?
NoSQL之redis缓存雪崩、穿透、击穿概念解决办法
锁定和并发控制(一)
js商品总价格、最高价格商品、排除重复商品[初版]
Navicat for mysql cracked versions installed
Coordinate knowledge in digital twin campus scenarios
Kubernetes:(七)优化大法(江湖失传已久的武林秘籍)
Mysql开启binlog
npm install报错Fix the upstream dependency conflict, or retry
数字孪生园区场景中的坐标知识
Detailed explanation of the principle of JWT_The principle of electromagnetic induction
一文搞懂│php 中的 DI 依赖注入
默认参数的代码实现及日期的注入与显示
实时数仓架构演进及选型
sql2008数据库置疑的解决方法_sqlserver2008数据库可疑
接入网学习笔记
Special Variables (SQL)
融云「 IM 进阶实战高手课」系列直播上线
蔚来杯2022牛客暑期多校训练营5 ABCDFGHK
VMware启动报错:另一个程序已锁定文件的一部分,进程无法访问(删除最近的.lck文件夹)









