命名空间
变体
操作

std::ranges::generate_random

来自 cppreference.cn
< cpp‎ | algorithm‎ | ranges
 
 
算法库
受约束算法和范围算法 (C++20)
受约束算法,例如 ranges::copy, ranges::sort, ...
执行策略 (C++17)
排序及相关操作
划分操作
排序操作
二分搜索操作
(在已划分范围上)
集合操作(在已排序范围上)
合并操作(在已排序范围上)
堆操作
最小值/最大值操作
(C++11)
(C++17)
字典序比较操作
排列操作
C 库
数值操作
未初始化内存上的操作
 
受约束算法
此菜单中的所有名称均属于命名空间 std::ranges
非修改序列操作
修改序列操作
划分操作
排序操作
二分搜索操作(在已排序范围上)
       
       
集合操作(在已排序范围上)
堆操作
最小值/最大值操作
       
       
排列操作
折叠操作
数值操作
(C++23)            
随机数生成
generate_random
(C++26)
未初始化存储上的操作
返回类型
 
定义于头文件 <random>
调用签名
template< class R, class G >

    requires ranges::output_range<R, std::invoke_result_t<G&>> &&
             std::uniform_random_bit_generator<std::remove_cvref_t<G>>
constexpr ranges::borrowed_iterator_t<R>

    generate_random( R&& r, G&& g );
(1) (since C++26)
template< class G, std::output_iterator<std::invoke_result_t<G&>> O,

          std::sentinel_for<O> S >
    requires std::uniform_random_bit_generator<std::remove_cvref_t<G>>
constexpr O

    generate_random( O first, S last, G&& g );
(2) (since C++26)
template< class R, class G, class D >

    requires ranges::output_range<R, std::invoke_result_t<D&, G&>> &&
             std::invocable<D&, G&> &&
             std::uniform_random_bit_generator<std::remove_cvref_t<G>> &&
             std::is_arithmetic_v<std::invoke_result_t<D&, G&>>
constexpr ranges::borrowed_iterator_t<R>

    generate_random( R&& r, G&& g, D&& d );
(3) (since C++26)
template< class G, class D, std::output_iterator<std::invoke_result_t<D&, G&>> O,

          std::sentinel_for<O> S >
    requires std::invocable<D&, G&> &&
             std::uniform_random_bit_generator<std::remove_cvref_t<G>> &&
             std::is_arithmetic_v<std::invoke_result_t<D&, G&>>
constexpr O

    generate_random( O first, S last, G&& g, D&& d );
(4) (since C++26)

尝试使用随机数生成器或分布的 generate_random 成员函数生成随机数,预计效率更高。如果 generate_random 成员函数不可用,则回退到逐元素生成。

让回退操作为调用 ranges::generate(std::forward<R>(r), std::ref(g))ranges::generate(std::forward<R>(r), [&d, &g] { return std::invoke(d, g); }) 分别对应 (1)(3)

1) 调用 g.generate_random(std::forward<R>(r)),如果此表达式良好构成。
否则,设 Istd::invoke_result_t<G&>。如果 R 建模 sized_range,则使用 ranges::size(r)I 类型的值填充 r,方法是执行未指定次数的 g()g.generate_random(s) 形式的调用(如果对于值 N 和类型为 std::span<I, N> 的对象 s,此类表达式良好构成)。
否则,执行回退操作。
3) 调用 d.generate_random(std::forward<R>(r), g),如果此表达式良好构成。
否则,设 Istd::invoke_result_t<D&, G&>。如果 R 建模 sized_range,则使用 ranges::size(r)I 类型的值填充 r,方法是执行未指定次数的 std::invoke(d, g)d.generate_random(s, g) 形式的调用(如果对于值 N 和类型为 std::span<I, N> 的对象 s,此类表达式良好构成)。
否则,执行回退操作。
2,4) 分别等效于 (1,3),其中 rranges::subrange<O, S>(std::move(first), last) 获得。

如果 (1)(3) 的效果与相应回退操作的效果不等效,则行为未定义。

N 的值在不同调用之间可能有所不同。实现可以选择较小的值用于较短的范围。

此页面上描述的类函数实体是算法函数对象(俗称 niebloid),即

内容

[编辑] 参数

first, last - 定义要写入随机数的元素范围的迭代器-哨兵对
r - 要写入随机数的range
g - 均匀随机位生成器
d - 随机数分布对象

[编辑] 注解

std::ranges::generate_random 标准化时,标准库中没有随机数生成器或分布提供 generate_random 成员函数。

当与包装底层向量化 API 的用户定义随机数生成器一起使用时,std::ranges::generate_random 可能会更有效率。

特性测试 Std 特性
__cpp_lib_ranges_generate_random 202403L (C++26) std::ranges::generate_random

[编辑] 示例

#include <algorithm>
#include <iomanip>
#include <iostream>
#include <random>
 
int main()
{
    std::default_random_engine eng;
    std::default_random_engine::result_type rs[16]{};
    std::ranges::generate_random(rs, eng);
 
    std::cout << std::left;
    for (int i{}; auto n : rs)
        std::cout << std::setw(11) << n << (++i % 4 ? ' ' : '\n');
}

可能的输出

16807       282475249   1622650073  984943658 
1144108930  470211272   101027544   1457850878
1458777923  2007237709  823564440   1115438165
1784484492  74243042    114807987   1137522503

[编辑] 参见

将函数的结果保存在范围中
(算法函数对象)[编辑]
指定类型符合均匀随机位生成器的条件
(概念) [编辑]