C++ 算法 fill() 函數用於使用 operator= 為指定範圍 [first, end) 中的每個元素分配相同的新值。
注:Range [first, last) 表示範圍內包含first,不包含last。
用法
template <class ForwardIterator, class T>
void fill (ForwardIterator first, ForwardIterator last, const T& val);
參數
first:一個前向迭代器,指向指定範圍內第一個元素的位置。
last:一個前向迭代器,指向要遍曆的範圍中最後一個元素之後的位置。
val:要分配給範圍 [first, last) 中元素的值。
返回值
空
複雜度
複雜性在 first 和 last 內的距離以及每個元素的分配上是線性的。
數據競爭
範圍 [first1, last1) 中的對象被修改,其中每個對象隻被訪問一次。
異常安全
此函數拋出異常元素賦值或迭代器上的操作拋出異常。
請注意,無效參數會導致未定義的行為。
例子1
讓我們看一個簡單的例子來演示 fill() 的使用:
#include <algorithm>
#include <iostream>
#include <vector>
using namespace std;
int main() {
vector<int> v(5);
fill(v.begin(), v.end(), 2);
for_each(v.begin(), v.end(), [](int x) { cout << x << ","; });
return 0;
}
輸出:
2,2,2,2,2,
例子2
讓我們看另一個簡單的例子:
#include <iostream> // std::cout
#include <algorithm> // std::fill
#include <vector> // std::vector
using namespace std;
int main () {
vector<int> myvector (8); // myvector:0 0 0 0 0 0 0 0
fill (myvector.begin(),myvector.begin()+4,5); // myvector:5 5 5 5 0 0 0 0
fill (myvector.begin()+3,myvector.end()-2,8); // myvector:5 5 5 8 8 8 0 0
cout << "myvector contains:";
for (vector<int>::iterator it=myvector.begin(); it!=myvector.end(); ++it)
cout << ' ' << *it;
cout << '\n';
return 0;
}
輸出:
myvector contains:5 5 5 8 8 8 0 0
例子3
讓我們看另一個簡單的例子:
#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;
return 0;
}
輸出:
Vector v1 = ( 0 5 10 15 20 25 30 35 40 45 ) Modified v1 = ( 0 5 10 15 20 2 2 2 2 2 )
示例 4
讓我們看另一個簡單的例子:
#include <algorithm>
#include <vector>
#include <iostream>
#include <iomanip>
using namespace std;
void print(const vector <int>& v)
{
vector <int>::const_iterator i;
for(i = v.begin(); i != v.end(); i++)
{
cout << setw(2) << *i << " ";
}
cout << endl;
}
int main()
{
int arr[] = { 0, 1, 2, 3, 4, 5, 6, 7, 8, 9 };
vector <int> v(arr, arr + sizeof(arr) / sizeof(int));
cout << "Vector before fill" << endl;
print(v);
fill(v.begin() + 4, v.end() - 3, -1);
cout << "Vector after fill" << endl;
print(v);
}
輸出:
Vector before fill 0 1 2 3 4 5 6 7 8 9 Vector after fill 0 1 2 3 -1 -1 -1 7 8 9
相關用法
- C++ Algorithm fill_n()用法及代碼示例
- C++ Algorithm remove_if()用法及代碼示例
- C++ Algorithm remove()用法及代碼示例
- C++ Algorithm max_element()用法及代碼示例
- C++ Algorithm set_union()用法及代碼示例
- C++ Algorithm next_permutation()用法及代碼示例
- C++ Algorithm upper_bound()用法及代碼示例
- C++ Algorithm minmax()用法及代碼示例
- C++ Algorithm remove_copy_if()用法及代碼示例
- C++ Algorithm random_shuffle()用法及代碼示例
- C++ Algorithm pop_heap()用法及代碼示例
- C++ Algorithm replace()用法及代碼示例
- C++ Algorithm set_intersection()用法及代碼示例
- C++ Algorithm lower_bound()用法及代碼示例
- C++ Algorithm transform()用法及代碼示例
- C++ Algorithm set_difference()用法及代碼示例
- C++ Algorithm is_sorted()用法及代碼示例
- C++ Algorithm equal_range()用法及代碼示例
- C++ Algorithm minmax_element()用法及代碼示例
- C++ Algorithm stable_sort()用法及代碼示例
注:本文由純淨天空篩選整理自 C++ Algorithm fill()。非經特殊聲明,原始代碼版權歸原作者所有,本譯文未經允許或授權,請勿轉載或複製。