generate
分配给每个元素的函数对象生成的值在范围内。
template<class ForwardIterator, class Generator>
void generate(
ForwardIterator _First,
ForwardIterator _Last,
Generator _Gen
);
参数
_First
解决仅向前迭代器的第一个元素的位置在值将分配的大小。_Last
解决仅向前的迭代器通过最终元素的位置某个值将分配的大小。_Gen
调用没有参数用于创建将要赋值的值设置为每个范围内的元素的函数对象。
备注
每次调用,函数对象为该范围内的每个元素调用,并且不需要返回相同的值。 它可以,例如,从文件读取或请参见和修改本地状态。 生成器的结果类型必须可用于向前迭代的值类型该范围的。
该范围引用必须是有效的;所有指针必须dereferenceable,因此,在序列中,最后位置必须是可访问的从开始按增量。
复杂是线性,与正确(_Last – _First)调用生成器需要。
示例
// alg_generate.cpp
// compile with: /EHsc
#include <vector>
#include <deque>
#include <algorithm>
#include <iostream>
#include <ostream>
int main( )
{
using namespace std;
// Assigning random values to vector integer elements
vector <int> v1 ( 5 );
vector <int>::iterator Iter1;
deque <int> deq1 ( 5 );
deque <int>::iterator d1_Iter;
generate ( v1.begin ( ), v1.end ( ) , rand );
cout << "Vector v1 is ( " ;
for ( Iter1 = v1.begin( ) ; Iter1 != v1.end( ) ; Iter1++ )
cout << *Iter1 << " ";
cout << ")." << endl;
// Assigning random values to deque integer elements
generate ( deq1.begin ( ), deq1.end ( ) , rand );
cout << "Deque deq1 is ( " ;
for ( d1_Iter = deq1.begin( ) ; d1_Iter != deq1.end( ) ; d1_Iter++ )
cout << *d1_Iter << " ";
cout << ")." << endl;
}
要求
标头: <algorithm>
命名空间: std