学习笔记

C_CPP超大规模随机数

jxtxzzw · 3月28日 · 2018年 603次已读

本文写于 2018年03月28日,距今已超过 1 年,距 2018年11月02日 的最后一次修改也已超过 3 个月,部分内容可能已经过时,您可以按需阅读。如果图片无法显示或者下载链接失效,请给我反馈,谢谢!


在解决百万皇后问题的时候,需要产生超大规模的随机数
然而rand()并不能完成这个需求
下面给出一个C++下的超大规模随机数生成器

typedef std::subtract_with_carry_engine<std::uint_fast64_t, 48, 5, 12> ranlux48_base;
ranlux48_base rb;

可以输出rb.min()rb.max()看看这个东西的范围
rb()生成一个随机数
数据的范围是unsingned long long int,如果需要使用类似int r = rb() % N的语句,需要做类型转换

1 条回应
    jxtxzzw 2018-4-1 · 15:12
    Chrome 63.0.3239.132 Linux

    如果需要负数的随机数,其实可以利用int r = rb()的溢出来完成