c++中map的基本用法和嵌套用法实例分析
本文实例讲述了c++中map的基本用法和嵌套用法。分享给大家供大家参考。具体分析如下:
C++中map容器提供一个键值对容器,map与multimap差别仅仅在于multiple允许一个键对应多个值。本文主要总结一下map基本用法和嵌套用法示例。
一、map基本用法
1.头文件
#include<map>
2.定义
map<int,int>my_Map;//注意这里的int和int可以是其他类型
或者是
typedefmap<int,int>MY_MAP; MY_MAPmy_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)
inti=my_Map[1]; my_Map[1]=i;
(2)
MY_MAP::iteratormy_Itr; my_Itr.find(2); intj=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>>::iteratormultitr; //以下是如何遍历本multiMap map<int,int>::iteratorintertr; 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=newmap<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++程序设计有所帮助。