如何正确地生成一个随机数

参考文章
笔记 | 如何正确地生成一个随机数
CF曾提到:Don’t use rand(): a guide to random number generators in C++
文章总结:
1 .rand()的随机范围太小了,在某些平台下(例如 Windows)RAND_MAX 只有 32768。如果需要的范围大于 32768,那么指定 min 和 max 参数就可以生成大于 RAND_MAX 的数了,或者考虑用 mt_rand() 来替代它。
2. random_shuffle(打乱数组顺序)
3. rand()使用的伪随机算法是 linear congruential generator (线性同余发生器),在低位循环节很低
rand()不行那咋办?文章中给了东西:mt19937(范围:无限制,可以自己设定),mt19937是c++11中加入的新特性,具有速度快,周期长的特点
无范围:
使用方法:

#include<random>
#include<ctime>
std::mt19937 rnd(time(0));
int main()
{printf("%lld\n",rnd());return 0;
}

C++无范围限制

#include <iostream>
#include <chrono>
#include <random>
using namespace std;
int main()
{// 随机数种子unsigned seed = std::chrono::system_clock::now().time_since_epoch().count();mt19937 rand_num(seed);	 // 大随机数cout << rand_num() << endl;return 0;
}

手动加上范围:

#include <iostream>
#include <chrono>
#include <random>
using namespace std;
int main()
{// 随机数种子unsigned seed = std::chrono::system_clock::now().time_since_epoch().count();mt19937 rand_num(seed);  // 大随机数uniform_int_distribution<long long> dist(0, 1000000000);  // 给定范围cout << dist(rand_num) << endl;return 0;
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/316042.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

一篇短文带您了解一下EasyCaching

前言从2017年11月11号在Github创建EasyCaching这个仓库&#xff0c;到现在也已经将近一年半的时间了&#xff0c;基本都是在下班之后和假期在完善这个项目。由于EasyCaching目前只有英文的文档托管在Read the Docs上面&#xff0c;当初选的MkDocs现在还不支持多语言&#xff0c…

[开源]OSharpNS - .net core 快速开发框架 - 简介

OSharpNS全称OSharp Framework with .NetStandard2.0&#xff0c;是一个基于.NetStandard2.0开发的一个.NetCore快速开发框架。这个框架使用最新稳定版的.NetCore SDK&#xff08;当前是.NET Core 2.2&#xff09;&#xff0c;对 AspNetCore 的配置、依赖注入、日志、缓存、实体…

Ozon Tech Challenge 2020 (Div.1 + Div.2, Rated, T-shirts + prizes!)

Ozon Tech Challenge 2020 (Div.1 Div.2, Rated, T-shirts prizes!) 题号题目知识点AKuroni and the GiftsBKuroni and Simple StringsCKuroni and Impossible CalculationDKuroni and the Celebration思维EKuroni and the Score Distribution构造FKuroni and the Punishmen…

Web 版 VS Code (Visual Studio Online) 即将来临!

今天&#xff08;北京时间 2019 年 5 月 7 日&#xff09;&#xff0c;在微软Build 2019开发者大会上&#xff0c;微软宣布了 Web 版本的 VS Code - Visual Studio Online。相信读者们对Web 版 VS Code 期待已久了。对 VS Code 熟悉的朋友应该知道&#xff0c;VS Code 是基于 E…

CF1305D Kuroni and the Celebration

CF1305D Kuroni and the Celebration 题意&#xff1a; 给你一棵有 n 个节点的树。对于每次询问&#xff0c;提交两个点&#xff0c;评测机会返回这两个点的 LCA。求树根。 询问格式为 ? u v&#xff0c;此时评测机会返回 u 和 v 的 LCA。 提交格式为 ! x&#xff0c;表示…

CF1305F Kuroni and the Punishment

CF1305F Kuroni and the Punishment 题意&#xff1a; 给定 n 个数。每次可以选择将一个数 1 或 -1 。求至少多少次操作使得整个序列都是正数且全部元素的 gcd>1 。 n<2e5,ai<1012n<2e5,a_{i}<10^{12}n<2e5,ai​<1012 题解&#xff1a; 首先不难想到&…

2019年了,C#发展的怎么样了呢?

C# 8.0我估计大多数程序员对于C# 5.0之后的改进都没有什么太多的认知&#xff0c;的确从C# 5.0开始C#已经没什么太多东西可以从其他语言借鉴&#xff0c;Anders的重心也开始逐步倾斜到TypeScript&#xff0c;所以从5.0引入async之后C#语言发展速度开始减缓了。C#6引入了大量的语…

微软宣布新命令行工具 Windows Terminal 和 WSL2

微软在 Build 2019 已经宣布推出名为Windows Terminal的新款命令行工具 , 这款工具可以访问多种环境的中心位置。例如可以直接访问PowerShell、CMD.EXE、Windows Linux子系统等等&#xff0c;开发者使用此工具可以简化工作。这款新工具支持多选项卡同时连接多个环境或服务器&a…

CF1305E Kuroni and the Score Distribution

CF1305E Kuroni and the Score Distribution 题意&#xff1a; 题解&#xff1a; 一开始想这个题&#xff0c;想法是一开始顺着填1&#xff0c;2&#xff0c;3…然后多删少补 如果1&#xff0c;2&#xff0c;3&#xff0c;4…这样顺延的填&#xff0c;对于akka_{k}kak​k可以…

微软 Build 2019:Windows 10 隐退,IE 重生,Azure 成主角

019 年 5 月 6 日&#xff0c;一年一度的微软 Build 开发者大会正式到来。作为本次大会最为重磅的 Keynote 环节&#xff0c;微软 CEO Satya Nadella 的开场演讲无疑展示了这家巨头对于未来科技发展趋势的洞察和判断&#xff0c;并且也能够让人更加清晰地看到微软在 Azure 云计…

牛客练习赛89

牛客练习赛89 题号题目知识点A牛牛吃米粒贪心B牛牛嚯可乐搜索C牛牛吃豆人思维D牛牛种小树思维完全背包E牛牛小数点思维推导F牛牛防疫情最小割

普通人看Build 2019 值得留心的亮点有哪些?

一场Keynote下来&#xff0c;是不是对纳德拉那套“Azure&#xff0c;azure&#xff0c;azure”&#xff0c;云云云的套路感觉有些乏味呢&#xff1f;当然这也不是你的问题&#xff0c;原本Build大会就是为开发者而设的&#xff0c;将近两个小时下来没看到什么能让自己眼前一亮的…

牛牛种小树

牛牛种小树 题意&#xff1a; 他打算用他得到的米粒去构造一棵有n个节点的树&#xff0c;并使得它的价值最大。 设f(d)表示树上度数为d的一个点能够获取的最大价值。则这棵树的价值为∑i1nf(di)\sum_{i1}^nf(d_{i})∑i1n​f(di​),其中did_{i}di​表示第i个点的度数 题解&am…

Build 2019:微软正式宣布 .NET 5

今天&#xff0c;我们宣布 .NET Core 3.0 之后的下一个版本将是 .NET 5 。这将是 .NET 系列的下一个重要版本。将来只会有一个 .NET &#xff0c;您将能够使用它来开发 Windows&#xff0c;Linux&#xff0c;macOS&#xff0c;iOS&#xff0c;Android&#xff0c;tvOS&#xff…

LGV定理

老早就听说&#xff0c;一直没学&#xff0c;今天遇到一个LGV比较裸的题&#xff0c;特地学习一下 选自oi-wiki 定义&#xff1a; e(u,v)表示u到v这条路径上所有边的边权之积(路径计数时&#xff0c;可以将边权都设为1),很多路径统计问题就是用到这一点 引理&#xff1a; 答案…

2019牛客多校Monotonic Matrix

Monotonic Matrix 题意&#xff1a; 问有多少个n * m的矩阵A满足一下情况&#xff1a;答案mod 1e97 矩阵A的所有元素∈{0,1,2}Ai,j<Ai1,jA_{i,j}<A_{i1,j}Ai,j​<Ai1,j​Ai,j<Ai,j1A_{i,j}<A_{i,j1}Ai,j​<Ai,j1​ 题解&#xff1a; 我们先看看这个式子…

WPF框架教程 | 从0到1:使用Caliburn.Micro(WPF和MVVM)开发简单的计算器

之前时间一直在使用Caliburn.Micro这种应用了MVVM模式的WPF框架做开发&#xff0c;是时候总结一下了。Caliburn.Micro(https://blog.csdn.net/lzuacm/article/details/78886436)是一个轻量级的WPF框架&#xff0c;简化了WPF中的不少用法&#xff0c;推荐做WPF开发时优先使用。真…

微软全都要!Win10引入真Linux内核

继将 Bash shell、原生 OpenSSH、WSL 引入 Windows&#xff0c;以及在微软商店提供 Ubuntu、SUSE Linux 和 Fedora 等发行版&#xff0c;正在举办的 Microsoft Build 2019 大会上&#xff0c;微软又宣布了一个重大的决定 —— 将完整的 Linux 内核引入 Windows 10。按照微软的说…

牛客练习赛89--牛牛防疫情

牛牛防疫情 题意&#xff1a; 牛牛用卖烤串赚的钱买了一款游戏&#xff0c;这款游戏的地图是一个 n*n 的网格&#xff0c;其中有 m 个地区存在感染源&#xff08;红色&#xff09;&#xff0c;其余地区为安全区&#xff08;白色&#xff09;。已知一个感染源可同时将与其相邻…

Kafka基本知识整理

首先Kafka是一个分布式消息队列中间件&#xff0c;Apache顶级项目&#xff0c;https://kafka.apache.org/ 高性能、持久化、多副本备份、横向扩展。生产者Producer往队列里发送消息&#xff0c;消费者Consumer从队列里消费消息&#xff0c;然后进行业务逻辑。应用场景主要有&…