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.示例如下:
[cpp] view plain copy
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.
也可以这样:
[cpp] view plain copy
map<int,map<int,int>* >multiMap;
map<int, int>* temp = new map<int, int>;
multiMap[10]=temp;
这样动态new内存,就要记得delete,否则会有内存泄露,delete如下:
[cpp] view plain copy
map<int, int>* temp1;
for(multitr=multiMap.begin();multitr!=multiMap.end();multitr++)
{
temp1 = multitr ->second;
delete temp1;
temp1 = NULL;
}
转载请注明原创链接:http://blog.csdn.net/wujunokay/article/details/12163549
map的嵌套特别注意:
1,对于 std::map(std::string, std::map<std::string, string>) 这个类型的赋值和插入方法:
std::map<std::string, std::string> neimap;
std::map<std::string, std::map<std::string, std::string> > waimap;
std::string group = "groupp";
waimap[group] = neimap;
std::string key = "keyy";
std::string value = "valuee";
waimap[group].insert(std::make_pair(key.c_str(), value.c_str()));
注意必须用: waimap[group].insert(std::make_pair(key.c_str(), value.c_str())); 给内层的map赋值(make_pair中的std::string要写作char类型),否则,在有些编译器下是编译不过的。