您的位置:首页 > 编程语言 > C语言/C++

c++中map的基本用法和嵌套用法

2013-10-17 17:33 405 查看
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
plaincopy

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
plaincopy

map<int,map<int,int>* >multiMap;

map<int, int>* temp = new map<int, int>;

multiMap[10]=temp;

这样动态new内存,就要记得delete,否则会有内存泄露,delete如下:

[cpp] view
plaincopy

map<int, int>* temp1;

for(multitr=multiMap.begin();multitr!=multiMap.end();multitr++)

{

temp1 = multitr ->second;

delete temp1;

temp1 = NULL;

}

转载请注明原创链接:/article/1628065.html
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: