C++中的STL中map用法详解(零基础入门)

目录
  • 一、什么是 map ?
  • 二、map的定义
    • 2.1 头文件
    • 2.2 定义
    • 2.3 方法
  • 三、实例讲解
    • 3.1 增加数据
    • 3.2 删除数据
    • 3.3 修改数据
    • 3.4 查找数据
    • 3.5 遍历元素
    • 3.6 其它方法
  • 四、总结

map 在编程中是经常使用的一个容器,本文来讲解一下 STL 中的 map,赶紧来看下吧!

一、什么是 map ?

map 是具有唯一键值对的容器,通常使用红黑树实现。

map 中的键值对是 key value 的形式,比如:每个身份证号对应一个人名(反过来不成立哦!),其中,身份证号就是 key,人名便是 value,是单项的关系,可以与 hash 作类比。

二、map的定义

2.1 头文件

使用 map 需要引入头文件,如下所示:

#include <map>

2.2 定义

定义形式如下所示:

map<key_type, value_type>变量名

注意:如果没有 using namespace std, map需要写成 std:map。

来看一个简单的例子:

#include <iostream>
#include <map>  // 头文件
#include <string>
using namespace std;

int main() {
    map<int, string>node;   // 定义变量
    node[123456] = "张三";

    cout<<"身份证号123456的人叫"<<node[123456]<<endl;
}

输出为:

身份证号123456的人叫张三

在上例中,定义了一个key 为 int ,value 为 string 的 map 容器 node。

2.3 方法

map 最常见的方法如下所示:

//常用
size()     // 计算元素个数
empty()    // 判断是否为空,空返回 true
clear()    // 清空容器
erase()    // 删除元素
find()     // 查找元素
insert()   // 插入元素
count()    // 计算指定元素出现的次数
begin()    // 返回迭代器头部
end()      // 返回迭代器尾部

//非常用
swap()        // 交换两个map容器,类型需要相同
max_size()    // 容纳的最大元素个数
rbegin()      // 指向map尾部的逆向迭代器
rend()        // 指向map头部的逆向迭代器
lower_bound() // 返回键值大于等于指定元素的第一个位置
upper_bound() // 返回键值大于指定元素的第一个位置
equal_range() // 返回等于指定元素的区间

三、实例讲解

3.1 增加数据

方法1:以数组下标的形式直接增加,即:变量名[key] = value 的形式。

#include <iostream>
#include <map>  // 头文件
#include <string>
using namespace std;

int main() {
    map<int, string>node;   // 定义变量
    node[123456] = "张三";
    node[123457] = "李四";
    node[123458] = "王五";

    cout<<"身份证号123456的人叫"<<node[123456]<<endl;
    cout<<"身份证号123457的人叫"<<node[123457]<<endl;
    cout<<"身份证号123458的人叫"<<node[123458]<<endl;
}

输出为:

身份证号123456的人叫张三
身份证号123457的人叫李四
身份证号123458的人叫王五

方法2:直接插入键值对。

#include <iostream>
#include <map>  // 头文件
#include <string>
using namespace std;

int main() {
    map<int, string>node;   // 定义变量

    node.insert(pair<int, string>(123456, "张三"));
    node.insert(pair<int, string>(123457, "张三"));
    node.insert(pair<int, string>(123458, "李四"));

    cout<<"身份证号123456的人叫"<<node[123456]<<endl;
    cout<<"身份证号123457的人叫"<<node[123457]<<endl;
    cout<<"身份证号123458的人叫"<<node[123458]<<endl;
}

输出为:

身份证号123456的人叫张三
身份证号123457的人叫张三
身份证号123458的人叫李四

其中,pair 定义了一个键值对,对应 map 的 key 和 value。

3.2 删除数据

删除数据使用到 map 的 erase 和 clear方法,来看一下例子:

#include <iostream>
#include <map>  // 头文件
#include <string>
using namespace std;

int main() {
    map<int, string>node;   // 定义变量

    node[123456] = "张三";
    node[123457] = "李四";
    node[123458] = "王五";
    cout<<"size = "<<node.size()<<endl;
    //1. 使用 key 删除
    node.erase(123456);  // 删除 key = 123456 的节点
    cout<<"size = "<<node.size()<<endl;
    //2. 使用迭代器删除
    map<int,string>::iterator iter = node.find(123457);
    node.erase(iter);
    cout<<"size = "<<node.size()<<endl;
    //3. 清空整个容器
    node.clear();
    cout<<"size = "<<node.size()<<endl;
}

输出为:

size = 3
size = 2
size = 1
size = 0

其中,clear 方法表示清空容器,size 方法表示获取容器大小。

3.3 修改数据

修改数据仅能修改 value 的值,key 是不能修改的,可以通过增加和删除来实现修改 key。

#include <iostream>
#include <map>  // 头文件
#include <string>
using namespace std;

int main() {
    map<int, string>node;   // 定义变量

    node[123456] = "张三";
    cout<<"身份证号123456的人叫"<<node[123456]<<endl;
    node[123456] = "李四";
    cout<<"身份证号123456的人叫"<<node[123456]<<endl;
}

输出为:

身份证号123456的人叫张三
身份证号123456的人叫李四

3.4 查找数据

查找数据通过 find 函数来实现,如下所示:

#include <iostream>
#include <map>  // 头文件
#include <string>
using namespace std;

int main() {
    map<int, string>node;   // 定义变量

    node[123456] = "张三";
    node[123457] = "李四";
    node[123458] = "王五";
    map<int, string>::iterator iter = node.find(123456);
    if(iter != node.end()) {
        cout<<"身份证号123456的人叫"<<iter->second<<endl;
    }
}

输出为:

身份证号123456的人叫张三
find 方法返回的是 map 的迭代器。

3.5 遍历元素

遍历元素使用迭代器的方式,如下所示:

#include <iostream>
#include <map>  // 头文件
#include <string>
using namespace std;

int main() {
    map<int, string>node;   // 定义变量

    node[123456] = "张三";
    node[123457] = "李四";
    node[123458] = "王五";
    map<int, string>::iterator iter; //定义迭代器 iter
    for(iter = node.begin(); iter != node.end(); ++iter) {
        cout<<"身份证号"<<iter->first<<"的人叫"<<iter->second<<endl;
    }
}

输出为:

身份证号123456的人叫张三
身份证号123457的人叫李四
身份证号123458的人叫王五

其中,使用迭代器 iter 遍历容器,可以将迭代器理解为一个存储了 key 和 value 的一个结构,first 对应 key,second 对应 value。

3.6 其它方法

(1)swap 函数

交换两个 map 容器的内容,map 容器的类型必须相同,例如:

#include <iostream>
#include <map>  // 头文件
#include <string>
using namespace std;

int main() {
    map<int, string>node1;   // 定义变量
    map<int, string>node2;

    node1[11] = "张三";
    node1[12] = "李四";

    node2[21] = "王五";
    node2[22] = "赵六";
    node2[23] = "孙七";

    node1.swap(node2);
    map<int, string>::iterator iter;
    cout<<"node1 :"<<endl;
    for(iter = node1.begin(); iter != node1.end(); ++iter) {
        cout<<"key = "<<iter->first<<" value = "<<iter->second<<endl;
    }

    cout<<"node2 :"<<endl;
    for(iter = node2.begin(); iter != node2.end(); ++iter) {
        cout<<"key = "<<iter->first<<" value = "<<iter->second<<endl;
    }
}

输出为:

node1 :
key = 21 value = 王五
key = 22 value = 赵六
key = 23 value = 孙七
node2 :
key = 11 value = 张三
key = 12 value = 李四

(2)max_size

返回当前容器的可以容纳的最大元素个数,来看一个例子。

#include <iostream>
#include <map>  // 头文件
#include <string>
using namespace std;

int main() {
    map<int, string>node;   // 定义变量

    cout<<"max_size = "<<node.max_size()<<endl;

    node[11] = "张三";
    cout<<"max_size = "<<node.max_size()<<endl;

    node[12] = "李四";
    cout<<"max_size = "<<node.max_size()<<endl;

    node[13] = "王五";
    cout<<"max_size = "<<node.max_size()<<endl;
}

输出为:

max_size = 128102389400760775
max_size = 128102389400760775
max_size = 128102389400760775
max_size = 128102389400760775

(3)rbegin 和 rend

rbegin 和 rend 为反向迭代器,即:rbegin 指向最后一个元素,rend 指向第一个元素的前一个位置,来看一个例子。

#include <iostream>
#include <map>  // 头文件
#include <string>
using namespace std;

int main() {
    map<int, string>node;   // 定义变量

    node[11] = "张三";
    node[12] = "李四";
    node[13] = "王五";

    map<int, string>::reverse_iterator iter;
    for(iter = node.rbegin(); iter != node.rend(); ++iter) {
        cout<<"key = "<<iter->first<<" value = "<<iter->second<<endl;
    }
}

输出为:

key = 13 value = 王五
key = 12 value = 李四
key = 11 value = 张三

注意:迭代器需要使用反向迭代器。

(4)lower_bound 和 upper_bound

#include <iostream>
#include <map>  // 头文件
#include <string>
using namespace std;

int main() {
    map<int, string>node;   // 定义变量

    node[20] = "张三";
    node[15] = "李四";
    node[12] = "王五";

    map<int, string>::iterator iter = node.lower_bound(14);
    cout<<"key = "<<iter->first<<" value = "<<iter->second<<endl;

    iter = node.upper_bound(12);
    cout<<"key = "<<iter->first<<" value = "<<iter->second<<endl;
}

输出结果为:

key = 15 value = 李四
key = 15 value = 李四

(5)equal_range

#include <iostream>
#include <map>  // 头文件
#include <string>
using namespace std;

int main() {
    map<int, string>node;   // 定义变量

    node[12] = "张三";
    node[15] = "李四";
    node[20] = "王五";

    pair<map<int, string>::iterator, map<int, string>::iterator> p = node.equal_range(15);

    cout<<"key1 = "<<p.first->first<<" value1 = "<<p.first->second<<endl;
    cout<<"key2 = "<<p.second->first<<" value2 = "<<p.second->second<<endl;
}

输出为:

key1 = 15 value1 = 李四
key2 = 20 value2 = 王五

四、总结

编程中经常使用到 key / value 的形式表示数据之间的关系,故 map 是 STL 中经常使用的一个容器,需要记住 map 的常用方法。

到此这篇关于C++中的STL中map用法详解(零基础入门)的文章就介绍到这了,更多相关C++ STL map用法内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!

(0)

相关推荐

  • 最短时间学会基于C++实现DFS深度优先搜索

    目录 前言 1.迷宫找出口,区分dfs,bfs: 一.DFS经典放牌可能组合 二.leetcode 员工的重要性 三.leetcode 图像渲染 四.leetcode 被围绕的区域 五.岛屿数量 六. 小练习:岛屿的最大面积 总结 前言 同学们肯定或多或少的听到过别人提起过DFS,BFS,却一直都不太了解是什么,其实两个各为搜索算法,常见使用 深度优先搜索(DFS) 以及 广度优先搜索(BFS) ,今天我们就来讲讲什么是深度优先搜索,深度优先就是撞到了南墙才知道回头,才会往上一层返回. 1.迷宫

  • C++ Invalidaterect()函数作用案例详解

    函数原型: BOOLInvalidateRect( HWND hWnd, // handle of window withchanged update region 窗口句柄. CONST RECT *lpRect, // address ofrectangle coordinates rect结构体的指针. BOOL bErase // erase-background flag 是否要发送WM_ERASEBKGND消息从而擦除原来的背景 ); 这个函数的作用是,使得Client的一个矩形区域

  • C++实现控制台随机迷宫的示例代码

    我全程使用TCHAR系列函数,亲测可以不改动代码兼容Unicode/ANSI开发环境,功能正常.大概有100行代码是来自网络的,我也做了改动,侵权请联系删除. 这个代码不能算是完美,还是会有轻微的闪屏现象,懒得再加双缓存了,大家可以自行修改.这里用的是SetConsoleCursorPosition函数和cls刷新屏幕. 好了,上代码!VS2015编译通过无警告.其他版本应该也没问题 // C++ Maze main code // Copyright (c) 2020 szx0427 #inc

  • 神奇的c/c++小游戏((提高你的编程兴趣)

    目录 神奇的c/c++ 神奇的c/c++ 以下代码在Dev,codeblocks,VC上都能运行 #include<stdio.h> #include<time.h> #include<stdlib.h> #include<conio.h> #include<windows.h> //下面Sleep()函数的头文件 #include<mmsystem.h> void menu() { printf(" ***********

  • protobuf c++编程笔记

    目录 字段内容的定义 修饰符 字段类型 引用方式 不同字段的方法 1)optional修饰的基本类型: 2)optional修饰的对象类型: 3)repeated修饰的基本类型: 4)repeated修饰的对象类型: 序列化 反序列化 总结 字段内容的定义 //文件名:addressbook.proto syntax = "proto2";//proto版本 //.proto文件新增一个可选的package声明符,用来防止不同的消息类型有命名冲突. //包的声明符会根据使用语言的不同影

  • VSCODE调试RDKit内核的方法步骤(C++)

    目录 安装 RDKit 所需环境 配置 VSCode 使其能 Debug 配置 Intellisense 配置 CMake 新建调试文件进行调试 Anaconda 环境问题 参考资料 在研究 RDKit 的一些算法的时候,总希望能够"进入到代码中"看这些变量到底是什么,哪些代码块会被执行.可 RDKit 的编译比较复杂,如果是 Python 的部分,那么可以直接在 VSCode 中进行调试,记得在 launch 中设置 "justMyCode: false",详见该

  • C++ random_shuffle()方法案例详解

    假设你需要指定范围内的随机数,传统的方法是使用ANSI C的函数random(),然后格式化结果以便结果是落在指定的范围内.但是,使用这个方法至少有两个缺点. 首先,做格式化时,结果常常是扭曲的,所以得不到正确的随机数(如某些数的出现频率要高于其它数) 其次,random()只支持整型数:不能用它来产生随机字符,浮点数,字符串或数据库中的记录. 对于以上的两个问题,C++中提供了更好的解决方法,那就是random_shuffle()算法.不要着急,下面我就会告诉你如何用这种算法来产生不同类型的随

  • C++ GetDlgItem用法案例详解

    GetDlgItem的用法小结 GetDlgItem用于获得指定控件ID的窗体指针,函数原型如下: HWND GetDlgItem( HWND hDlg, int nIDDlgItem ); CWnd* GetDlgItem(int nID) const; 它的使用说明中有这样一行字,**The returned pointer may be temporary and should not be stored for later use. **,那说明,它返回的指针有可能是有效的,有可能是无效

  • C++中的STL中map用法详解(零基础入门)

    目录 一.什么是 map ? 二.map的定义 2.1 头文件 2.2 定义 2.3 方法 三.实例讲解 3.1 增加数据 3.2 删除数据 3.3 修改数据 3.4 查找数据 3.5 遍历元素 3.6 其它方法 四.总结 map 在编程中是经常使用的一个容器,本文来讲解一下 STL 中的 map,赶紧来看下吧! 一.什么是 map ? map 是具有唯一键值对的容器,通常使用红黑树实现. map 中的键值对是 key value 的形式,比如:每个身份证号对应一个人名(反过来不成立哦!),其中

  • 浅谈c++中的stl中的map用法详解

    Map是STL的一个关联容器,它提供一对一(其中第一个可以称为关键字,每个关键字只能在map中出现一次,第二个可能称为该关键字的值)的数据处理能力,由于这个特性,它完成有可能在我们处理一对一数据的时候,在编程上提供快速通道.这里说下map内部数据的组织,map内部自建一颗红黑树(一种非严格意义上的平衡二叉树),这颗树具有对数据自动排序的功能,所以在map内部所有的数据都是有序的,后边我们会见识到有序的好处. 下面举例说明什么是一对一的数据映射.比如一个班级中,每个学生的学号跟他的姓名就存在着一一

  • JSP 中request与response的用法详解

    JSP 中request与response的用法详解 概要: 在学习这两个对象之前,我们应该已经有了http协议的基本了解了,如果不清楚http协议的可以看我的关于http协议的介绍.因为其实request和response的使用大部分都是对http协议的操作. request对象的介绍 我们先从request对象进行介绍: 我们知道http协议定义了请求服务器的格式: 请求行 请求头 空格 请求体(get请求没有请求体) 好了,这里我们就不详细介绍了,我们只看几个应用就可以了,没什么难度: 应

  • C++中auto_ptr智能指针的用法详解

    智能指针(auto_ptr) 这个名字听起来很酷是不是?其实auto_ptr 只是C++标准库提供的一个类模板,它与传统的new/delete控制内存相比有一定优势,但也有其局限.本文总结的8个问题足以涵盖auto_ptr的大部分内容. auto_ptr是什么? auto_ptr 是C++标准库提供的类模板,auto_ptr对象通过初始化指向由new创建的动态内存,它是这块内存的拥有者,一块内存不能同时被分给两个拥有者.当auto_ptr对象生命周期结束时,其析构函数会将auto_ptr对象拥有

  • IOS开发中NSURL的基本操作及用法详解

    NSURL其实就是我们在浏览器上看到的网站地址,这不就是一个字符串么,为什么还要在写一个NSURL呢,主要是因为网站地址的字符串都比较复杂,包括很多请求参数,这样在请求过程中需要解析出来每个部门,所以封装一个NSURL,操作很方便. 1.URL URL是对可以从互联网上得到的资源的位置和访问方法的一种简洁的表示,是互联网上标准资源的地址.互联网上的每个文件都有一个唯一的URL,它包含的信息指出文件的位置以及浏览器应该怎么处理它. URL可能包含远程服务器上的资源的位置,本地磁盘上的文件的路径,甚

  • JavaScript中SetInterval与setTimeout的用法详解

    setTimeout 描述 setTimeout(code,millisec) setTimeout() 方法用于在指定的毫秒数后调用函数或计算表达式. 注:调用过程中,可以使用clearTimeout(id_of_settimeout)终止 参数 描述 code 必需,要调用的函数后要执行的 JavaScript 代码串. millisec 必需,在执行代码前需等待的毫秒数. setTimeinterval setInterval(code,millisec[,"lang"]) 参数

  • Linux中 sed 和 awk的用法详解

    sed用法: sed是一个很好的文件处理工具,本身是一个管道命令,主要是以行为单位进行处理,可以将数据行进行替换.删除.新增.选取等特定工作,下面先了解一下sed的用法 sed命令行格式为: sed [-nefri] 'command' 输入文本 常用选项: -n∶使用安静(silent)模式.在一般 sed 的用法中,所有来自 STDIN的资料一般都会被列出到萤幕上.但如果加上 -n 参数后,则只有经过sed 特殊处理的那一行(或者动作)才会被列出来. -e∶直接在指令列模式上进行 sed 的

  • Python中index()和seek()的用法(详解)

    1.index() 一般用处是在序列中检索参数并返回第一次出现的索引,没找到就会报错,比如: >>> t=tuple('Allen') >>> t ('A', 'l', 'l', 'e', 'n') >>> t.index('a') Traceback (most recent call last): File "<pyshell#2>", line 1, in <module> t.index('a') V

  • jquery 中toggle的2种用法详解(推荐)

    一.在元素的click事件中绑定两个或两个以上的函数  toggle不像bind需要在后面添加"click"来绑定click触发事件,toggle本身就是click触发的(而且只能click触发), 如下实例: <input id="btntest" type="button" value="点一下我" /> <div>我是动态显示的</div> <script type="

  • 逻辑表达式中与或非的用法详解

    先说逻辑与(&&),它可以从三个层次进行理解 第一个层次最简单,就是简单的布尔值之间的逻辑与,就是左值和右值都是true时,返回true,两边都是false或者两边的值其中一边是fasle,就返回false:(AND操作): 第二个层次,(false,null,indefined,0,-0,NaN和""这些都是假值,其他所有的值包括对象都是真值),对这些"真值"和"假值"进行AND操作,返回一个"真值"或者&q

随机推荐