C++ STL 中的 multimap swap() 函式
在本文中,我們將討論 C++ STL 中 multimap swap() 函式的工作原理、語法和示例。
什麼是 C++ STL 中的 Multimap?
Multimap 是關聯容器,類似於 map 容器。它還便於以特定順序儲存由鍵值和對映值組合形成的元素。在 multimap 容器中,可以有多個元素與同一個鍵關聯。資料在內部始終藉助其關聯的鍵進行排序。
什麼是 multimap swap()?
multimap::swap() 函式是 C++ STL 中的內建函式,它在 <map> 標頭檔案中定義。swap() 用於交換兩個 multimap 容器的內容。此函式交換兩個 multimap 容器的值,而不管這兩個 multimap 容器的大小如何。
當此函式被呼叫時,它接受另一個 multimap 容器作為引數,並將其內容與關聯的容器交換。
語法
multimap_name.swap(multimap& multimap_name2);
引數
該函式接受以下引數:
map_name2 - 這是另一個 multimap 容器的物件,我們希望將其資料與關聯的 multimap 容器交換。
返回值
此函式不返回任何值。
輸入
std::multimap<char, int> odd, eve; odd.insert(make_pair(‘a’, 1)); odd.insert(make_pair(‘b’, 3)); odd.insert(make_pair(‘c’, 5)); eve.insert(make_pair(‘d’, 2)); eve.insert(make_pair(‘e’, 4)); eve.insert(make_pair(‘f’, 6)); odd.swap(eve);
輸出
Odd: d: 2 e:4 f:6 Eve: a:1 b:3 c:5
示例
#include<iostream>
#include<map>
using namespace std;
int main(){
multimap<int,int > mul_1;
multimap<int,int> mul_2;
//declaring iterator to traverse the elements
multimap<int,int>:: iterator i;
//inserting elements to multimap1
mul_1.insert({1,10});
mul_1.insert({2,20});
mul_1.insert({3,30});
mul_1.insert({4,40});
mul_1.insert({5,50});
//inserting elements to multimap2
mul_2.insert({6,60});
mul_2.insert({7,70});
mul_2.insert({8,80});
mul_2.insert({9,90});
//calling swap to swap the elements
mul_1.swap(mul_2);
//elements of multimap1
cout<<"Elements in multimap1 are: "<<"\n";
for( i = mul_1.begin(); i!= mul_1.end(); i++){
cout<<(*i).first<<" "<< (*i).second << "\n";
}
//elements of multimap2
cout<<"\nElements in multimap2 are: ";
for( i = mul_2.begin(); i!= mul_2.end(); i++){
cout<<(*i).first<<" "<<(*i).second << "\n";
}
}輸出
如果我們執行上述程式碼,它將生成以下輸出:
Elements in multimap1 are: 6 60 7 70 8 80 9 90 Elements in multimap2 are: 1 10 2 20 3 30 4 40 5 50
廣告
資料結構
網路
RDBMS
作業系統
Java
iOS
HTML
CSS
Android
Python
C 程式設計
C++
C#
MongoDB
MySQL
Javascript
PHP