fill

新分配相同的值设置为在指定的范围内的每个元素。

template<class ForwardIterator, class Type> 
   void fill( 
      ForwardIterator _First,  
      ForwardIterator _Last,  
      const Type& _Val 
   );

参数

  • _First
    处理第一元素的位置将向前迭代器遍历的范围。

  • _Last
    寻址最终元素的前向迭代器将遍历一位置的范围。

  • _Val
    将赋值为处于范围 [_First,_Last) 的元素。

备注

目标范围必须是有效的;所有指针必须是不可引用的,并且通过增量可从第一个到达最后一个。 复杂性与范围大小是线性关系。

示例

// alg_fill.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( v1.begin( ) + 5, v1.end( ), 2 );

   cout << "Modified v1 = ( " ;
   for ( Iter1 = v1.begin( ) ; Iter1 != v1.end( ) ; Iter1++ )
      cout << *Iter1 << " ";
   cout << ")" << endl;
}
  

要求

标头: <算法>

命名空间: std

请参见

参考

标准模板库