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

更新於: 2020-04-22

159 次檢視

開啟您的 職業生涯

透過完成課程獲得認證

開始學習
廣告

© . All rights reserved.