C++库为我们提供了很多生成随机数的方法。

使用C的随机数生成法

先学过C语言,或者仅仅用C++做算法的人。对rand()是非常熟悉了。这个函数没有参数,生成0到RAND_MAX的随机数(RAND_MAX随环境可能是16位范围或32位范围)。

#include <stdlib.h>
#include <stdio.h>
#include <time.h> main() {
srand(time(0)); // 以当前时间初始化随机数种子 for (int i = 0; i < 12; i++)
printf("%d ", rand());
printf("\n%d", RAND_MAX);
} /* output:
54662053 670906658 1153043822 1421129869 1473191568 431426198 458863543 103837017 1196255552 740286342 625267246 1994847783
2147483647
*/

一般我们用当前unix时间(即time(0)的值)初始化随机种子,这样每次运行时种子都可以不同,保证每次运行得到不同的随机数结果。在我的机器上,RAND_MAX值为2147483647,即所有31位正数的范围。

使用C++的随机数生成法

C语言的rand函数功能还是太局限。在生成特定范围的数或者实数的时候很不方便。

C++提供了全新的方式使用随机数。首先,使用random头文件,可以定义一个default_ranbdom_engine

#include <random>
#include <iostream>
using namespace std; main(){
default_random_engine a; cout << "min: " << a.min() << endl;
cout << "max: " << a.max() << endl;
for (int i = 0; i < 12; i++)
cout << a() << ' '; //! 生成下一个数
}
/*
min: 1
max: 2147483646
16807 282475249 1622650073 984943658 1144108930 470211272 101027544 1457850878 1458777923 2007237709 823564440 1115438165
*/

这个“随机数引擎”是一个可调用对象,与rand()非常相似,不过在多线程时可以定义很多个一起用。同时也需要在构造时(或使用成员函数seed赋值种子,否则默认构造下种子相同,每次都会生成相同的随机数)。一般来讲,最好把它定义成静态或全局变量。如果作为局部变量的话,则每次都会从相同的种子重新开始。

//C++ Primer上的例子
auto random_vector() {
default_random_engine eng; vector<int> a(12);
for (int i = 0; i < 12; i++) a[i] = eng();
}
/*
这个函数返回一个填充随机值的vector,但是他每次运行都会使用相同种子,生成完全一样的值。 把eng定义为static就可以解决这个问题。 或者也可以使用time(0),但time(0)是以秒为单位的,若调用太快仍会得到相同的结果
*/

除了随机数引擎,我们还可以使用随机数分布对象。分布对象可以用调用引擎生成随机数,再调整出适当范围内的随机数,比如下面这个:

main(){
default_random_engine a; uniform_int_distribution<short> x(12, 90); //整数生成器 cout << "min: " << x.min() << endl;
cout << "max: " << x.max() << endl;
for (int i = 0; i < 12; i++)
cout << x(a) << ' '; //! 生成下一个数
}
/*
min: 12
max: 90
12 22 71 48 54 29 15 65 65 85 42 53
*/

uniform_int_distribution可以指定任意整数类型和上下界值(闭区间),在范围内均匀生成对应的随机整数,不过他每次生成数据时要代一个引擎作为参数,也就是说,他是根据引擎生成的值再调整出来的,自己不具有生成随机数的功能,所以叫做“随机数分布对象”。再介绍些其他分布对象:

uniform_real_distribution<double> eng(min, max);// 浮点数均匀分布
normal_distribution<int> eng(average, SD); // 整数正态分布,需要方差和中间值
bernoulli_distribution eng(pro) //伯努利分布,生成true和false,可以指定true的概率

把真正生成随机数的东西和调整分布的东西分开是有好处的。因为随机数生成必须使用外部变量,占用额外空间。而调整阶段是不用的。因此,即使程序各个地方都在用随机数,也只需要一个default_random_engine

C++库的随机数生成的更多相关文章

  1. 《利用python进行数据分析》读书笔记--第四章 numpy基础:数组和矢量计算

    http://www.cnblogs.com/batteryhp/p/5000104.html 第四章 Numpy基础:数组和矢量计算 第一部分:numpy的ndarray:一种多维数组对象 实话说, ...

  2. 【C/C++】随机数的生成

    C/C++:rand()函数 rand()函数的头文件:#include<stdlib.h> 该函数产生的随机数随机性差,速度慢,周期小(0-32767) 用法如下所示: #include ...

  3. CUDA随机数生成库curand——deviceAPI

    原创作品,如要转载请注明出处:http://www.cnblogs.com/shrimp-can/p/6590152.html 最近要在device函数中使用curand库生成随机数,查找了下资料,除 ...

  4. Java实验--课上提到的随机数生成原理简单实现(不利用库生成随机数的简单算法)

    对于随机数的实验,根据课程上的教程,有如下的公式: 对应的变量参数的说明: 其中对应的Mouduls变量对应的就是公式中a的值,在公式中的含义就是相当于要循环多少个数才重复的一个值. Multipli ...

  5. Alg-4:算法可视化tiny库的实现

    好吧,准备好好实践一下<算法>这本书的内容的,有点讨厌的是这本书是以Java作为示例语言的(好吧,我承认我有语言偏见,Java就是臭).其中有一个Std库,其中涉及到简化输入输出.随机数生 ...

  6. 【C】 06 - 标准库概述

    任何程序都会有一些通用的功能需求,对这些需求的实现组成了库.它可以提高程序的复用性.健壮性和可移植性,这也是模块化设计的体现.C规范定义了一些通用接口库,这里只作概述性介绍,具体细节当然还是要查阅规范 ...

  7. Lo-Dash – 替代 Underscore 的优秀 JS 工具库

    前端开发人员大都喜欢 Underscore,它的工具函数很实用,用法简单.这里给大家推荐另外一个功能更全面的 JavaScript 工具——Lo-Dash,帮助你更好的开发网站和 Web 应用程序. ...

  8. C/C++ 开源库及示例代码

    C/C++ 开源库及示例代码 Table of Contents 说明 1 综合性的库 2 数据结构 & 算法 2.1 容器 2.1.1 标准容器 2.1.2 Lockfree 的容器 2.1 ...

  9. (五)boost库之随机数random

    (五)boost库之随机数random boost库为我们提供了许多的日常随机数生成器: 1.uniform_smallint:在小整数域内的均匀分布 2.uniform_int:在整数域上的均匀分布 ...

随机推荐

  1. rabbitmq简单运用

    <?php /** * 生产者 */ $connection = new AMQPConnection([ 'host' => '192.168.23.130', 'port' => ...

  2. gin框架使用【3.路由参数】

    GET url: http://127.0.0.1:8080/users/{id} http://127.0.0.1:8080/users/1   对于id值的获取 package main impo ...

  3. 把图片存储 canvas原生API转成base64

    1.LocalStorage有什么用? 2.LocalStorage的普通用法以及如何存储图片. 首先介绍下什么是LocalStorage 它是HTML5的一种最新储存技术.但它只能储存字符串.以前的 ...

  4. MySQL 的 GRANT和REVOKE 命令

    MySQL 的 GRANT和REVOKE 命令 GRANT - 授权 将指定 操作对象 的指定 操作权限 授予指定的 用户; 发出该 GRANT语句的可以是数据库管理员,也可以是该数据库对象的创建者; ...

  5. jmeter并发设置的原理

    目录 简介 广义并发 绝对并发 简介 ​ 性能测试过程中是否需要进行同步定时器的设置,需要根据实际情况来考虑. ​ 举个栗子来讲是我们的双十一秒杀活动,这时候就必须实现请求数量达到一定数量后同时向服务 ...

  6. jmeter工具初探

    jmeter工具初探 一.jmeter工具介绍 1.一种免费的java开源工具,可以进行二次开发 2.运行环境:java运行环境,需要安装JDK,配置JAVAHOME 环境变量 3.下载jmeter: ...

  7. 记一次sql注入的解决方案

    点赞再看,养成习惯,微信搜索「小大白日志」关注这个搬砖人. 本文在公众号文章已同步,还有各种一线大厂面试原题.我的学习系列笔记. 今天业务提了个模糊查询,一听就知道这种问题有坑,肯定涉及到sql注入, ...

  8. python学习-Day38-HTTP

    目录 HTTP简介 可以充当客户端的有哪些 HTTP 工作原理 HTTP协议 HTTP协议四大特性 数据格式 请求格式: 响应格式: HTTP 请求方法 HTTP 状态码分类 响应分为五类: HTTP ...

  9. Linux网络流量相关

    一直以来对Linux网络这块都感觉比较乱 遇到一个UDP丢包的问题:在测试中,一台VM虚拟机,CPU利用率55%左右,内存利用率7%左右,网卡流量也远没到限制的时候出现了丢包情况 使用netstat ...

  10. 网络爬虫、Pandas

    网络爬虫.Pandas Pandas 是 Python 语言的一个扩展程序库,用于数据分析. Pandas 是一个开放源码.BSD 许可的库,提供高性能.易于使用的数据结构和数据分析工具. Panda ...