c++中map的基本用法和嵌套用法实例分析

 更新时间:2015年01月12日 14:46:02   投稿:shichen2014  
这篇文章主要介绍了c++中map的基本用法和嵌套用法,以实例形式分析了map容器的基本使用技巧,具有一定参考借鉴价值,需要的朋友可以参考下

本文实例讲述了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++程序设计有所帮助。

相关文章

  • C语言改造通讯录操作详解

    C语言改造通讯录操作详解

    这篇文章主要介绍了C语言文件操作改造通讯录方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习吧
    2023-01-01
  • Java C++ 算法题解leetcode669修剪二叉搜索树示例

    Java C++ 算法题解leetcode669修剪二叉搜索树示例

    这篇文章主要为大家介绍了Java C++ 算法题解leetcode669修剪二叉搜索树示例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-09-09
  • Matlab实现遗传算法的示例详解

    Matlab实现遗传算法的示例详解

    这篇文章主要为大家详细介绍了什么是遗传算法,以及如何利用Matlab从零开始自己写一个遗传算法函数,文中的代码对我们学习有一定帮助,需要的可以参考一下
    2022-03-03
  • C++读取配置文件的示例代码

    C++读取配置文件的示例代码

    这篇文章主要介绍了C++读取配置文件的示例代码,帮助大家更好的理解和学习C++开发,感兴趣的朋友可以了解下
    2020-08-08
  • C++模板 index_sequence使用示例详解

    C++模板 index_sequence使用示例详解

    这篇文章主要为大家介绍了C++模板 index_sequence使用示例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-12-12
  • 模拟鼠标事件的实现思路及代码

    模拟鼠标事件的实现思路及代码

    这篇文章主要介绍了模拟鼠标事件的实现思路及代码,有需要的朋友可以参考一下
    2013-12-12
  • c++调用动态库LNK2019和LNK1120无法解析的外部命令

    c++调用动态库LNK2019和LNK1120无法解析的外部命令

    本文主要介绍了c++调用动态库LNK2019和LNK1120无法解析的外部命令, 出现这个错误一般都是函数只找到声明但没有实现,或者是少了什么链接库,下面就来解决一下
    2024-06-06
  • C语言实现磁盘映射

    C语言实现磁盘映射

    磁盘映射技术通过将文件映射到内存中,提高了文件操作的效率,本文就来介绍一下C语言实现磁盘映射,感兴趣的可以了解一下
    2024-09-09
  • C++基于回溯法解决八皇后问题示例

    C++基于回溯法解决八皇后问题示例

    这篇文章主要介绍了C++基于回溯法解决八皇后问题,简单描述了八皇后问题,以及回溯法的原理与解决八皇后问题的相关操作技巧,需要的朋友可以参考下
    2017-11-11
  • C语言container of()函数案例详解

    C语言container of()函数案例详解

    这篇文章主要介绍了C语言container of()函数案例详解,本篇文章通过简要的案例,讲解了该项技术的了解与使用,以下就是详细内容,需要的朋友可以参考下
    2021-08-08

最新评论