生成
为每个元素的函数对象生成的值范围中。
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;
}
要求
标头: <算法>
命名空间: std