C++ 算法 replace() 函數用於將 [first, last) 範圍內所有等於 old_value 的值替換為 new_value 值。
此函數檢查範圍內的每個元素,如果與指定值匹配,則替換它。
用法
template <class ForwardIterator, class T>
void replace (ForwardIterator first, ForwardIterator last,
const T& old_value, const T& new_value);
參數
first:一個前向迭代器,指向元素被替換的範圍內的初始位置。
last:一個前向迭代器,指向元素被替換的範圍內的最終位置。
old_value:被替換元素的舊值。
new_value:分配給具有舊值的元素的新值。
返回值
空
複雜度
複雜性在 first 和 last 之間的距離上是線性的。它比較每個元素並分配給那些匹配的元素。
數據競爭
範圍 [first1, last1) 中的對象被訪問並可能被修改。
異常安全
如果任何函數調用賦值或迭代器上的操作拋出異常,則拋出異常。
請注意,無效參數會導致未定義的行為。
例子1
讓我們看一個簡單的例子來演示 replace() 的使用:
#include <algorithm>
#include <iostream>
#include <vector>
using namespace std;
int main() {
vector<int> v = { 3,1,2,1,2 };
replace(v.begin(), v.end(), 1, 10);
for_each(v.begin(), v.end(),
[](int x) { cout << x << ","; });
return 0;
}
輸出:
3,10,2,10,2,
在上麵的例子中,向量 v 的元素 1 被替換為 10。
例子2
讓我們看另一個簡單的例子:
#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( i );
int ii;
for ( ii = 0 ; ii <= 3 ; ii++ )
v1.push_back( 7 );
random_shuffle (v1.begin( ), v1.end( ) );
cout << "The original vector v1 is:\n ( " ;
for ( Iter1 = v1.begin( ) ; Iter1 != v1.end( ) ; Iter1++ )
cout << *Iter1 << " ";
cout << ")." << endl;
// Replace elements with a value of 7 with a value of 700
replace (v1.begin( ), v1.end( ), 7 , 700);
cout << "The vector v1 with a value 700 replacing that of 7 is:\n ( " ;
for ( Iter1 = v1.begin( ) ; Iter1 != v1.end( ) ; Iter1++ )
cout << *Iter1 << " ";
cout << ")." << endl;
return 0;
}
輸出:
The original vector v1 is: ( 4 7 7 7 0 5 7 1 6 9 3 7 8 2 ). The vector v1 with a value 700 replacing that of 7 is: ( 4 700 700 700 0 5 700 1 6 9 3 700 8 2 ).
在上麵的例子中,replace() 從向量 v1 中找到所有與 7 匹配的元素並將其替換為 700。
例子3
讓我們看另一個簡單的例子:
#include <iostream>
#include <vector>
#include <algorithm>
using namespace std;
void print(vector<int>& v)
{
for(int i = 0; i < v.size(); i++)
cout << v[i] << " ";
cout << endl;
}
int main() {
vector<int> v = {1, 4, 3, 2, 3, 10, 7, 9, 3, 8};
cout << "v:";
print(v);
// replace 3 with 6
replace(v.begin(), v.end(), 3, 6);
cout << "After replacing 3 with 6\n";
cout << "v:";
print(v);
return 0;
}
輸出:
v:1 4 3 2 3 10 7 9 3 8 After replacing 3 with 6 v:1 4 6 2 6 10 7 9 6 8
示例 4
讓我們看另一個簡單的例子:
#include <iostream> // cout
#include <algorithm> // replace
#include <vector> // vector
using namespace std;
int main () {
int myints[] = { 10, 20, 30, 30, 20, 10, 10, 20 };
vector<int> myvector (myints, myints+8); // 10 20 30 30 20 10 10 20
replace (myvector.begin(), myvector.end(), 20, 99); // 10 99 30 30 99 10 10 99
cout << "myvector contains:";
for (vector<int>::iterator it=myvector.begin(); it!=myvector.end(); ++it)
cout << ' ' << *it;
cout << '\n';
return 0;
}
輸出:
myvector contains:10 99 30 30 99 10 10 99
相關用法
- C++ Algorithm replace_copy()用法及代碼示例
- C++ Algorithm replace_copy_if()用法及代碼示例
- C++ Algorithm replace_if()用法及代碼示例
- C++ Algorithm remove_if()用法及代碼示例
- C++ Algorithm remove()用法及代碼示例
- C++ Algorithm remove_copy_if()用法及代碼示例
- C++ Algorithm reverse_copy()用法及代碼示例
- C++ Algorithm remove_copy()用法及代碼示例
- C++ Algorithm reverse()用法及代碼示例
- C++ Algorithm random_shuffle()用法及代碼示例
- C++ Algorithm rotate()用法及代碼示例
- C++ Algorithm rotate_copy()用法及代碼示例
- C++ Algorithm max_element()用法及代碼示例
- C++ Algorithm set_union()用法及代碼示例
- C++ Algorithm next_permutation()用法及代碼示例
- C++ Algorithm upper_bound()用法及代碼示例
- C++ Algorithm minmax()用法及代碼示例
- C++ Algorithm pop_heap()用法及代碼示例
- C++ Algorithm set_intersection()用法及代碼示例
- C++ Algorithm lower_bound()用法及代碼示例
注:本文由純淨天空篩選整理自 C++ Algorithm replace()。非經特殊聲明,原始代碼版權歸原作者所有,本譯文未經允許或授權,請勿轉載或複製。