C++RNG(随机数生成)优化

C++ RNG (Random Number Generation) Optimization

本文关键字:优化 随机数 C++RNG      更新时间:2023-10-16

首先,我想澄清一下,我对C++很陌生,我已经编写了一些代码,可以输出一组随机的16位数字。为此,我使用了一个在线教程和相对较高的批处理体验(这个想法来自一个运行速度相当慢的批处理文件,我想将两个批处理文件迁移到c++中,以比较它们的运行方式,因为有两个类似的项目,一个用于随机数生成,也就是这个项目,另一个用于生成随机字符串(。由于我对c++不是很在行,我想得到一些帮助来优化代码,因为我觉得这可以用更少的行完成既然你已经掌握了背景,我的代码如下

#include <iostream>
#include <cstdlib>
#include <ctime>
int main()
{
std::srand(std::time(0));
int random0 = 0;
int random1 = 0;
int random2 = 0;
int random3 = 0;
int random4 = 0;
int random5 = 0;
int random6 = 0;
int random7 = 0;
int random8 = 0;
int random9 = 0;
int random10 = 0;
int random11 = 0;
int random12 = 0;
int random13 = 0;
int random14 = 0;
int random15 = 0;

for (int i = 0; i < i+1; ++i)
{
random0 = std::rand() % 9;
random1 = std::rand() % 9;
random2 = std::rand() % 9;
random3 = std::rand() % 9;
random4 = std::rand() % 9;
random5 = std::rand() % 9;
random6 = std::rand() % 9;
random7 = std::rand() % 9;
random8 = std::rand() % 9;
random9 = std::rand() % 9;
random10 = std::rand() % 9;
random11 = std::rand() % 9;
random12 = std::rand() % 9;
random13 = std::rand() % 9;
random14 = std::rand() % 9;
random15 = std::rand() % 9;
std::cout << random0 << random1 << random2 << random3 << random4 << random5 << random6 << random7 << random8 << random9 << random10 << random11 << random12 << random13 << random14 << random15 << std::endl;
}
return 0;
}

提前感谢您的帮助,如果我触发了任何有经验的c++编码器的OCD,我很抱歉。

和我编写了一些代码,输出一组随机的16位数字。

我将其读取为打印0999999999999999之间的随机数。使用计算器,我将所有9位转换为大于32位但小于64位的23 86F2 6FC0 FFFF,因此我们可以使用uint64_t

生成随机数可以用std::uniform_int_distribution<uint64_t>完成,将生成的数字打印为16位是std::setwstd::setfill的任务

#include <random>
#include <iostream>
#include <iomanip>
int main()
{
std::random_device rd;  
std::mt19937 gen(rd()); 
uint64_t maxlim = 9999999999999999 ;
std::uniform_int_distribution<uint64_t> dis(0, maxlim);
std::cout << std::setfill('0') << std::setw(16) << dis(gen) << std::endl;
}

这仅对C++11及更高版本有效