Nota:
El acceso a esta página requiere autorización. Puede intentar iniciar sesión o cambiar directorios.
El acceso a esta página requiere autorización. Puede intentar cambiar los directorios.
Asigna un nuevo valor en un número especificado de elementos en un rango a partir de un elemento determinado.
template<class OutputIterator, class Size, class Type>
void fill_n(
OutputIterator _First,
Size _Count,
const Type& _Val
);
Parámetros
_First
Un iterador de salida que dirige la posición del primer elemento del intervalo para asignar el valor _Val._Count
Un con signo o un entero sin signo escribe especificar el número de elementos para asignar el valor._Val
El valor que se va a asignar a los elementos del intervalo [_First, _First + _Count).
Comentarios
El intervalo de destino debe ser válido; todos los punteros deben ser dereferenceable, y la posición última es accesible de primera por el aumento.La complejidad es lineal al tamaño del intervalo.
fill_n tiene dos formularios relacionados:
Para obtener información sobre cómo estas funciones se comportan, vea Iteradores comprobados.
Ejemplo
// alg_fill_n.cpp
// compile with: /EHsc
#include <vector>
#include <algorithm>
#include <iostream>
int main() {
using namespace std;
vector <int> v1;
vector <int>::iterator Iter1;
int i;
for ( i = 0 ; i <= 9 ; i++ )
v1.push_back( 5 * i );
cout << "Vector v1 = ( " ;
for ( Iter1 = v1.begin( ) ; Iter1 != v1.end( ) ; Iter1++ )
cout << *Iter1 << " ";
cout << ")" << endl;
// Fill the last 5 positions with a value of 2
fill_n( v1.begin( ) + 5, 5, 2 );
cout << "Modified v1 = ( " ;
for ( Iter1 = v1.begin( ) ; Iter1 != v1.end( ) ; Iter1++ )
cout << *Iter1 << " ";
cout << ")" << endl;
}
Output
Vector v1 = ( 0 5 10 15 20 25 30 35 40 45 )
Modified v1 = ( 0 5 10 15 20 2 2 2 2 2 )
Requisitos
encabezado: <algoritmo>
espacio de nombres: std