std::generate

来自cppreference.com
< cpp‎ | algorithm

 
 
算法库
执行策略 (C++17)
不修改的序列操作
(C++11)
(C++11)
(C++11)
(C++17)
修改的序列操作
未初始化存储上的操作
划分操作
排序操作
(C++11)
二分查找操作
集合操作(在已排序范围上)
堆操作
(C++11)
最小/最大操作
(C++11)
(C++17)

重排
数值操作
C 库
 
定义于头文件 <algorithm>
template< class ForwardIt, class Generator >
void generate( ForwardIt first, ForwardIt last, Generator g );
分配范围[first, last)生成的值给定的函数对象中的每个元素g
原文:
Assigns each element in range [first, last) a value generated by the given function object g.
文本通过谷歌翻译机器翻译。
你可以帮忙校正和验证翻译。点击此处查看指示。

目录

[编辑] 参数

first, last -
的范围内的元素来生成
原文:
the range of elements to generate
文本通过谷歌翻译机器翻译。
你可以帮忙校正和验证翻译。点击此处查看指示。
g - 将要调用的生成器函数。

签名应等价于下列者:

Ret fun();

类型 Ret 必须使得能解引用 ForwardIt 类型对象并对它赋 Ret 类型值。 ​

类型要求
-
ForwardIt 必须满足 ForwardIterator 的要求。

[编辑] 返回值

(无)
原文:
(none)
文本通过谷歌翻译机器翻译。
你可以帮忙校正和验证翻译。点击此处查看指示。

[编辑] 复杂度

究竟std::distance(first, last)g()和任务的调用.
原文:
Exactly std::distance(first, last) invocations of g() and assignments.
文本通过谷歌翻译机器翻译。
你可以帮忙校正和验证翻译。点击此处查看指示。

[编辑] 可能的实现

template<class ForwardIt, class Generator>
void generate(ForwardIt first, ForwardIt last, Generator g)
{
    while (first != last) {
        *first++ = g();
    }
}

[编辑] 示例

下面的代码使用填补了矢量随机数
原文:
The following code uses fills a vector with random numbers:
文本通过谷歌翻译机器翻译。
你可以帮忙校正和验证翻译。点击此处查看指示。

#include <algorithm>
#include <iostream>
#include <cstdlib>
 
int main()
{
    std::vector<int> v(5);
    std::generate(v.begin(), v.end(), std::rand); // Using the C function rand()
 
    std::cout << "v: ";
    for (auto iv: v) {
        std::cout << iv << " ";
    }
    std::cout << "\n";
}

输出:

v: 52894 15984720 41513563 41346135 51451456

[编辑] 另请参阅

将一个值赋给一个范围内的元素
(函数模板) [编辑]
保存函数的N次运行结果
(函数模板) [编辑]