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

C++中map容器提供一个键值对容器,map与multimap差别仅仅在于multiple允许一个键对应多个值。本文主要总结一下map基本用法和嵌套用法示例。

一、map基本用法
1头文件
#include

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.示例如下:

[cpp] view plain copy

  1. map<int,map<int,int>>multiMap;//对于这样的map嵌套定义,

  2. map<int,int>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>>::iteratormultitr;//以下是如何遍历本multiMap

  9. map<int,int>::iteratorintertr;

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

  11. {

  12. for(intertr=multitr->second.begin();intertr!=multitr->second.end();intertr++)

  13. cout<first<<“”<first<<“(”<second<<“)”<<endl;

  14. }

也可以这样:

[cpp] view plain copy

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

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

[cpp] view plain copy

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

转载请注明原创链接:http://blog.youkuaiyun.com/wujunokay/article/details/12163549

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值