命名空间
变体
操作

std::ranges::generate_random

来自 cppreference.cn
< cpp‎ | 算法‎ | 范围
 
 
算法库
有约束算法与针对范围的算法 (C++20)
有约束的算法,例如 ranges::copyranges::sort 等……
执行策略 (C++17)
排序及相关操作
划分操作
排序操作
二分搜索操作
(于已划分范围上)
集合操作(于已排序范围上)
归并操作(于已排序范围上)
堆操作
最小/最大值操作
(C++11)
(C++17)
字典序比较操作
排列操作
C 库
数值操作
未初始化内存上的操作
 
受约束算法
此菜单中的所有名称均属于命名空间 std::ranges
非修改序列操作
修改序列操作
划分操作
排序操作
二分查找操作(在已排序的范围内)
       
       
集合操作(于已排序范围上)
堆操作
最小/最大值操作
       
       
排列操作
折叠操作
数值操作
(C++23)            
随机数生成
generate_random
(C++26)
对未初始化存储的操作
返回类型
 
定义于头文件 <random>
调用签名 (Call signature)
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) (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) (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) (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) (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`,则通过执行未指定次数的 g()g.generate_random(s) 形式的调用(如果对于值 `N` 和类型为 std::span<I, N> 的对象 s,这样的表达式形式良好),用 ranges::size(r)I 类型的值填充 r
否则,执行回退操作。
3) 如果表达式 d.generate_random(std::forward<R>(r), g) 形式良好,则调用它。
否则,令 Istd::invoke_result_t<D&, G&>。如果 `R` 模拟 `sized_range`,则通过执行未指定次数的 std::invoke(d, g)d.generate_random(s, g) 形式的调用(如果对于值 `N` 和类型为 std::span<I, N> 的对象 s,这样的表达式形式良好),用 ranges::size(r)I 类型的值填充 r
否则,执行回退操作。
2,4) 分别等价于 (1,3),其中 rranges::subrange<O, S>(std::move(first), last) 获得。

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

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

本页描述的类函数实体是 算法函数对象(非正式地称为 niebloids),即

目录

[编辑] 参数

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

[编辑] 注意

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

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

特性测试 标准 特性
__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

[编辑] 参阅

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