当前位置: 首页 > news >正文

C/C++中设置随机数

前言

        我们通常在写一个数据结构后,需要去测试其正确性和性能比较,那在平常手动输入数据的方式太鸡肋,并且不具有普遍性和随机性。基于这个原因,我们必须要掌握设置随机数,不但可以给我们提供更多的数据,还可以让数据具有普遍意义,满足我们的测试需求。

一、有关随机数的函数

1. srand

void srand (unsigned int seed);

函数解析: 

        seed就相当于一颗种子,srand函数会种这个随机数种子,种子对应一个随机数,后面使用rand函数可以接收这个随机数。

        经过测试:当我们的种子是固定的,每次程序运行时,rand获得的随机数也是固定的,无法做到在一个程序里获得真正意义的随机数,所以参数通常使用的是time(NULL),time函数是获得系统的时间,因为系统的时间一直在变,那种子就也都是不同的,所以每次程序运行时,rand获得的数,也一直在变,这才是真正意义的随机数。

为什么参数一定时,获得的随机数是固定的?

        首先计算机并不能产生真正的随机数,而是将一些无规则排列的数字存储在电脑里,再把这些数字划分为相等的N份,并为每份加上一个编号。用srand()函数获取这个编号,然后rand()就按顺序获取这些数字。

头文件:

#include <stdlib.h>

参数seed:

推荐使用time(NULL),用时间做参数,可以保证每次程序运行时,生成的随机数是随机的

time函数头文件:#include <time.h>

返回值:

无返回值

2. rand

int rand (void);

头文件:

#include <stdlib.h>

函数解析:

        得到srand生成的随机数,并返回这个随机数

返回值:

        返回的是随机数,范围0~RAND_MAX(RAND_MAX = 2147483647)

二、测试模版

 int main()
{const size_t N = 10000;unordered_set<int> us;  //容器1set<int> s;             //容器2 vector<int> v;          //使用vector保存插入的数据v.reserve(N);           //防止多次扩容,造成消耗,提前一次预留N个空间srand(time(nullptr));   //种随机数种子,使用time做参数,可以保证每次运行,都是不一样的for (size_t i = 0; i < N; ++i){v.push_back(rand()); // N比较大时,重复值比较多//v.push_back(rand()+i); // 重复值相对少//v.push_back(i); // 没有重复,有序}//测试容器插入的性能size_t begin1 = clock();for (auto& e : v){s.insert(e);}size_t end1 = clock();cout << "set insert:" << end1 - begin1 << endl;size_t begin2 = clock();for (auto& e : v){us.insert(e);}size_t end2 = clock();cout << "unordered_set insert:" << end2 - begin2 << endl;//测试容器查找的性能size_t begin3 = clock();for (auto& e : v){s.find(e);}size_t end3 = clock();cout << "set find:" << end3 - begin3 << endl;size_t begin4 = clock();for (auto& e : v){us.find(e);}size_t end4 = clock();cout << "unordered_set find:" << end4 - begin4 << endl << endl;cout <<"插入数据个数:"<< s.size() << endl;cout <<"插入数据个数:" << us.size() << endl << endl;//测试容器删除的性能size_t begin5 = clock();for (auto& e : v){s.erase(e);}size_t end5 = clock();cout << "set erase:" << end5 - begin5 << endl;size_t begin6 = clock();for (auto e : v){us.erase(e);}size_t end6 = clock();cout << "unordered_set erase:" << end6 - begin6 << endl << endl;return 0;
}

三、反思与总结

        由于目前能力不足,还需要仔细研究源码中srand和rand的底层实现,在未来某段时间会更新剖析源码实现
random.c source code [glibc/stdlib/random.c] - Codebrowser

http://www.lryc.cn/news/339109.html

相关文章:

  • ARM 三个小灯闪烁
  • 创业之路:从市场洞察到产品实现的全方位指南
  • C++ 红黑树模拟实现
  • 【数据结构】第三节:单链表
  • Python中操作Excel表对象并打包为脚本
  • Python学习笔记23 - 目录操作
  • 今天你学langchain了吗?
  • 插值算法-代码实现
  • 113.PyQt5_QtPrintSupport_打印操作
  • 在vue中使用bing map 的小demo
  • 基于uni-app的埋点sdk设计
  • Python学习笔记(三)
  • Python办公自动化之Excel做表自动化:全网最全,看这一篇就够了!
  • 【学习笔记】R语言入门与数据分析1
  • MyBatis-Spring整合
  • 资深亚马逊运营实战技巧:跨境电商6大选品法
  • bugku-web-需要管理员
  • STM32之FreeRTOS移植
  • SpringBoot实用开发(十四)-- 消息(Message)的简单认识
  • 【Spring Boot 源码学习】SpringApplication 的 run 方法核心流程介绍
  • 如何保证消息不丢失?——使用rabbitmq的死信队列!
  • html、css、京东移动端静态页面,资源免费分享,可作为参考,提供InsCode在线运行演示
  • 头歌-机器学习 第13次实验 特征工程——共享单车之租赁需求预估
  • Unity 2D让相机跟随角色移动
  • 【面试题】s += 1 和 s = s + 1的区别
  • ARM的学习
  • Restful API接口规范(以Django为例)
  • AI助力,程序员压力倍增?
  • LoRA微调
  • 45.基于SpringBoot + Vue实现的前后端分离-驾校预约学习系统(项目 + 论文)