std::ranges::generate_n
来自 cppreference.cn
定义于头文件 <algorithm> |
||
调用签名 (Call signature) |
||
template< std::input_or_output_iterator O, std::copy_constructible F > requires std::invocable<F&> && std::indirectly_writable<O, std::invoke_result_t<F&>> |
(C++20 起) | |
将函数对象 gen 的连续调用结果赋值给范围 [
first,
first + n)
中的每个元素,如果 0 < n。否则不执行任何操作。
本页描述的类函数实体是 算法函数对象(非正式地称为 niebloids),即
目录 |
[编辑] 参数
first | - | 要修改的元素范围的起始 |
n | - | 要修改的元素数量 |
gen | - | 生成器函数对象。 |
[编辑] 返回值
如果 0 < count,则返回已赋值的最后一个元素之后一个位置的迭代器,否则返回 first。
[编辑] 复杂度
精确地调用 gen() n 次并进行赋值。
[编辑] 可能实现
struct generate_n_fn { template<std::input_or_output_iterator O, std::copy_constructible F> requires std::invocable<F&> && std::indirectly_writable<O, std::invoke_result_t<F&>> constexpr O operator()(O first, std::iter_difference_t<O> n, F gen) const { for (; n-- > 0; *first = std::invoke(gen), ++first) {} return first; } }; inline constexpr generate_n_fn generate_n {}; |
[编辑] 示例
运行此代码
#include <algorithm> #include <array> #include <iostream> #include <random> #include <string_view> auto dice() { static std::uniform_int_distribution<int> distr {1, 6}; static std::random_device engine; static std::mt19937 noise {engine()}; return distr(noise); } void print(const auto& v, std::string_view comment) { for (int i : v) std::cout << i << ' '; std::cout << '(' << comment << ")\n"; } int main() { std::array<int, 8> v; std::ranges::generate_n(v.begin(), v.size(), dice); print(v, "dice"); std::ranges::generate_n(v.begin(), v.size(), [n {0}] mutable { return n++; }); // same effect as std::iota(v.begin(), v.end(), 0); print(v, "iota"); }
可能的输出
5 5 2 2 6 6 3 5 (dice) 0 1 2 3 4 5 6 7 (iota)
[编辑] 参阅
(C++20) |
将一个函数的结果保存在一个范围中 (算法函数对象) |
(C++26) |
用来自均匀随机位生成器的随机数填充范围 (算法函数对象) |
(C++20) |
给一个范围的元素赋某个值 (算法函数对象) |
(C++20) |
给一定数量的元素赋一个值 (算法函数对象) |
(C++20) |
对一个范围的元素应用函数 (算法函数对象) |
将连续函数调用的结果赋给一个范围中的 N 个元素 (函数模板) |