map的基本用法和嵌套用法

C++中map容器提供一個鍵值對容器,map與multimap差別僅僅在於multiple允許一個鍵對應多個值。本文主要總結一下map基本用法和嵌套用法示例。

一、map基本用法
  1   頭文件 
  #include   <map> 


  2   定義 
  map<int,   int>   my_Map; //注意這裏的int和int可以是其他類型
  或者是typedef     map<int,   int>   MY_MAP; 
  MY_MAP   my_Map; 


  3   插入數據 
  (1)   my_Map[1]   =   1; 
  (2)   my_Map.insert(map<int, int>::value_type(2,2)); 
  (3)   my_Map.insert(pair<int,int>(3,3)); 
  (4)   my_Map.insert(make_pair<string,int>(4,4)); 
  
  4   查找數據和修改數據 
  (1)   int   i   =   my_Map[1]; 
            my_Map[1]   =   i; 
  (2)   MY_MAP::iterator   my_Itr; 
            my_Itr.find(2); 
            int   j   =   my_Itr->second; 
            my_Itr->second   =   j; 
注意:

A.鍵本身是不能被修改的,除非刪除。 

B.不管鍵存不存在,比如my_Map[1]   =   i;,都會執行賦值操作。
  
  5   刪除數據 
  (1)   my_Map.erase(my_Itr); 
  (2)   my_Map.erase(3); 

  
  6   遍歷數據 
  for   (my_Itr=my_Map.begin();   my_Itr!=my_Map.end();   ++my_Itr)   {} 
  
  7   其它方法 
  my_Map.size() :返回元素數目 
  my_Map.empty():判斷是否爲空 
  my_Map.clear() :清空所有元素 

二、嵌套用法

1.示例如下:

  1. map<int,map<int,int> >multiMap; //對於這樣的map嵌套定義,    
  2. map<intint> temp;    //定義一個map<int, string>變量,對其定義後在插入multiMap    
  3. temp[9] = 9;    
  4. temp[10] = 10;    
  5. multiMap[10] = temp;    
  6. multiMap[10][11]=11;     
  7. multiMap[5][30]=30;    
  8. map<int,map<int,int> >::iterator multitr;  // 以下是如何遍歷本multiMap    
  9. map<int,int>::iterator intertr;    
  10. for(multitr=multiMap.begin();multitr!=multiMap.end();multitr++)    
  11. {   
  12.     for(intertr= multitr ->second.begin(); intertr != multitr ->second.end(); intertr ++)    
  13.         cout<< multitr ->first<<" "<<intertr->first<<" ("<<intertr -> second <<")"<<endl;    
  14. }   

2.

也可以這樣:

  1. map<int,map<int,int>* >multiMap;  
  2. map<intint>* temp = new map<intint>;  
  3. multiMap[10]=temp;  

這樣動態new內存,就要記得delete,否則會有內存泄露,delete如下:

  1. map<intint>* temp1;  
  2. for(multitr=multiMap.begin();multitr!=multiMap.end();multitr++)    
  3. {   
  4.     temp1 = multitr ->second;  
  5.         delete  temp1;  
  6.         temp1 = NULL;  
  7. }   











原創鏈接:http://blog.csdn.net/wujunokay/article/details/12163549

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章