generate
範囲内の各要素に関数オブジェクトによって生成される値を割り当てます。
template<class ForwardIterator, class Generator>
void generate(
ForwardIterator _First,
ForwardIterator _Last,
Generator _Gen
);
パラメーター
_First
値が割り当てられた範囲内の先頭の要素の位置を示す前方反復子。_Last
値が割り当てられた範囲の最後の要素の一つ前の位置 1 に対処前方反復子。_Gen
引数なしで呼び出される関数オブジェクト範囲内の各要素に割り当てる値を生成する。
解説
関数オブジェクトは、範囲内の各要素に対して呼び出されるたびに開始され、同じ値を返す必要がありません。これは、たとえば、ファイルから読み取りまたはローカル状態を変更するには、表示されることがあります。ジェネレーターの結果の型のスコープの前方反復子の値型に変換できる必要があります。
参照される範囲が有効である必要があります; すべてのポインターが dereferenceable、シーケンス内では、最後の位置は incrementation によって最初から到達できる必要があります。
複雑度は、必要なジェネレーター (_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