本文實例講述了c++中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.示例如下:
map<int,map<int,int> >multiMap; //對于這樣的map嵌套定義,
map<int, int> temp; //定義一個map<int, string>變量,對其定義后在插入multiMap
temp[9] = 9;
temp[10] = 10;
multiMap[10] = temp;
multiMap[10][11]=11;
multiMap[5][30]=30;
map<int,map<int,int> >::iterator multitr; // 以下是如何遍歷本multiMap
map<int,int>::iterator intertr;
for(multitr=multiMap.begin();multitr!=multiMap.end();multitr++)
{
for(intertr= multitr ->second.begin(); intertr != multitr ->second.end(); intertr ++)
cout<< multitr ->first<<" "<<intertr->first<<" ("<<intertr -> second <<")"<<endl;
}
2.也可以這樣:
map<int,map<int,int>* >multiMap;
map<int, int>* temp = new map<int, int>;
multiMap[10]=temp;
這樣動態new內存,就要記得delete,否則會有內存泄露,delete如下:
map<int, int>* temp1;
for(multitr=multiMap.begin();multitr!=multiMap.end();multitr++)
{
temp1 = multitr ->second;
delete temp1;
temp1 = NULL;
}
希望本文所述對大家的C++程序設計有所幫助。