fill_n
Atribuir um novo valor a um número especificado de elementos em um intervalo começando com um elemento específico.
template<class OutputIterator, class Size, class Type>
OutputIterator fill_n(
OutputIterator First,
Size Count,
const Type& Val
);
Parâmetros
First
Um iterador de saída que trata a posição do primeiro elemento no intervalo a ter o valor Val atribuído.Count
Um tipo de inteiro com sinal ou sem sinal que especifica o número de elementos aos quais o valor será atribuído.Val
O valor a ser atribuído aos elementos no intervalo [First, First + Count).
Valor de retorno
Um iterador do elemento que segue o último elemento preenchido se Count > zero, caso contrário, segue o primeiro elemento.
Comentários
O intervalo de destino deve ser válido. Todos os ponteiros devem ser desreferenciável, e a última posição é alcançável a partir da primeira por incrementação. A complexidade é linear com o tamanho do intervalo.
fill_n tem dois formulários relacionados:
Para obter informações sobre como essas funções se comportam, consulte Iteradores Verificados.
Exemplo
// alg_fill_n.cpp
// compile using /EHsc
#include <vector>
#include <algorithm>
#include <iostream>
int main()
{
using namespace std;
vector <int> v;
for ( auto i = 0 ; i < 9 ; ++i )
v.push_back( 0 );
cout << " vector v = ( " ;
for ( const auto &w : v )
cout << w << " ";
cout << ")" << endl;
// Fill the first 3 positions with a value of 1, saving position.
auto pos = fill_n( v.begin(), 3, 1 );
cout << "modified v = ( " ;
for ( const auto &w : v )
cout << w << " ";
cout << ")" << endl;
// Fill the next 3 positions with a value of 2, using last position.
fill_n( pos, 3, 2 );
cout << "modified v = ( " ;
for ( const auto &w : v )
cout << w << " ";
cout << ")" << endl;
// Fill the last 3 positions with a value of 3, using relative math.
fill_n( v.end()-3, 3, 3 );
cout << "modified v = ( " ;
for ( const auto &w : v )
cout << w << " ";
cout << ")" << endl;
}
Saída
vector v = ( 0 0 0 0 0 0 0 0 0 )
modified v = ( 1 1 1 0 0 0 0 0 0 )
modified v = ( 1 1 1 2 2 2 0 0 0 )
modified v = ( 1 1 1 2 2 2 3 3 3 )
Requisitos
Cabeçalho: <algoritmo>
Namespace: std