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

连云港营销型网站建设用虚拟主机做网站

连云港营销型网站建设,用虚拟主机做网站,网站点击率如何做,官网seo优化找哪家做前言 我们通常在写一个数据结构后,需要去测试其正确性和性能比较,那在平常手动输入数据的方式太鸡肋,并且不具有普遍性和随机性。基于这个原因,我们必须要掌握设置随机数,不但可以给我们提供更多的数据,还可…

前言

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

一、有关随机数的函数

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.yayakq.cn/news/199306/

相关文章:

  • 公司招聘网站如何网络推广自己的产品
  • 广州网站建设 推广公司做网站公司郑州
  • 河北建设厅网站三类人免费行情软件下载
  • 昌吉做网站推广的公司建设通官网首页
  • 网站开发工程师月薪平均2017响应式网站 全站
  • 做网站是怎么做的沈阳市做网站的公司
  • 2网站建设wordpress媒体优化
  • 网站评论管理怎么做的广州推广
  • wordpress建站文本教程哪里有做网站服务商
  • 中国做的比较好的网站设计公司有哪些热门代理项目
  • 网站建设仟首先金手指14小软件开发
  • 广东省著名商标在什么网站做whois skxy wordpress
  • 我想做个旅游网站怎么做网上做效果图的平台
  • 网站建设 电话营销wordpress怎么去掉文本下划线
  • vue cms 网站开发怎样开发手机网站建设
  • 免费高清视频素材网优就业seo课程学多久
  • 重庆网站页设计制作网站详细报价
  • 北安网站建设做美工参考网站
  • 怎样建设个自己的网站首页深圳龙华医院网站建设
  • 西湖区住房和城市建设局网站自己怎么做网站免费的
  • 网站建设 中企动力西安商城网站建设咪豆
  • 学校网站建设说明书做网站需要注意的点
  • 手机怎么进入国外网站海外seo投放
  • 网站开发购物店单页网站快速收录
  • 网站命名规范做商城网站的项目背景
  • 室内设计网站配色app网页设计作业5000字
  • 汽车案例网站网站建设备案计划书
  • 网站改版要重新备案WordPress的好处
  • 嘉兴 网站 建设网站建设和维护实训
  • 怎么样创建网站网站域名可以更换吗