C&C++   发布时间:2022-04-03  发布网站:大佬教程  code.js-code.com
大佬教程收集整理的这篇文章主要介绍了c – 有没有办法可以获得0到10亿的随机数?大佬教程大佬觉得挺不错的,现在分享给大家,也给大家做个参考。
我现在不关心效率.我只是在找一个体面的方式,我可以生成从0到10亿的随机数.我已经尝试过rand()* rand(),但它只给了我估计超过大约1000万的数字.我希望范围更加分散.有人有什么建议吗?

解决方法

当然,只需使用C的现代 <random>设施:

std::random_device rd;
std::mt19937 gen(rd());
std::uniform_int_diStribution<> dis(1,1000000000);

for (int n=0; n<10; ++n)
    std::cout << dis(gen) << ' ';
std::cout << '\n';

(从here开始,略微修改以满足OP的需要)将满足您的需求.

如果需要,还存在浮点值的模拟函数.

备注:在不太可能的情况下,您的平台的int不能容纳10亿,或者如果您需要更大的数字,您还可以使用更大的整数类型,如下所示:

std::uniform_int_diStribution<std::int64_t> dis(1,1000000000);

另请注意,此处显示的播种mt不是最佳的;有关更多信息,请参阅我的问题here.

大佬总结

以上是大佬教程为你收集整理的c – 有没有办法可以获得0到10亿的随机数?全部内容,希望文章能够帮你解决c – 有没有办法可以获得0到10亿的随机数?所遇到的程序开发问题。

如果觉得大佬教程网站内容还不错,欢迎将大佬教程推荐给程序员好友。

本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。