返回顶部
首页 > 资讯 > 后端开发 > 其他教程 >C++中的STL中map用法详解(零基础入门)
  • 890
分享到

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

2024-04-02 19:04:59 890人浏览 独家记忆
摘要

目录一、什么是 map ? 二、map的定义 2.1 头文件 2.2 定义 2.3 方法 三、实例讲解 3.1 增加数据 3.2 删除数据 3.3 修改数据 3.4 查找数据

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用法内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!

--结束END--

本文标题: C++中的STL中map用法详解(零基础入门)

本文链接: https://lsjlt.com/news/133276.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • C++中的STL中map用法详解(零基础入门)
    目录一、什么是 map ? 二、map的定义 2.1 头文件 2.2 定义 2.3 方法 三、实例讲解 3.1 增加数据 3.2 删除数据 3.3 修改数据 3.4 查找数据...
    99+
    2024-04-02
  • Django零基础入门之常用过滤器详解
    引言: 前面讲过了Django中使用模板变量。使用很简单,那么有没有什么关于模板变量的骚操作呢? 答案是肯定有的,这就是本文要讲的——过滤器! 1.过滤器 (1)纯干货讲解: 作用:...
    99+
    2024-04-02
  • c++基础使用STL的注意点详解
    总结 本篇文章就到这里了,希望能够给你带来帮助,也希望您能够多多关注编程网的更多内容! ...
    99+
    2024-04-02
  • Jedis零基础入门及操作Redis中的数据结构详解
    目录Jedis简介及其入门Jedis简介Jedis的操作入门Jedis操作Redis中的数据结构字符串类型 string哈希类型 map列表类型 list集合类型 set有序集合类型...
    99+
    2024-04-02
  • Django零基础入门之模板变量详解
    引言: 我们在页面上会看到,谁登录的就会显示谁的信息,那么这个页面上的变量信息是怎样实现的呢? 这就是本文要讲述的内容——Django中的模板变量! 1.模板变量! 可以在前...
    99+
    2024-04-02
  • VUE零基础入门axios的使用
    目录一.axios是什么二.axios的特点三.axios怎么安装四.在VUE全局挂载导入挂载使用五.axios便捷方法六.axios基础方法七.axios执行结果八.config ...
    99+
    2024-04-02
  • C语言map函数的基础用法详解
    目录mapmap具体操作总结map 有N个学生的姓名name和学号ID,要求给你一个学生的name求查找他的ID。 简单做法是定义 string name [ N ] 和 int I...
    99+
    2024-04-02
  • C++深入分析STL中map容器的使用
    目录1、map容器2、map容器原理3、map容器函数接口4、使用示例1、map容器 map是C++ STL的一个关联容器,它提供一对一的数据处理能力。其中,各个键值对的键和值可以是...
    99+
    2024-04-02
  • Django零基础入门之路由path和re_path详解
    目录urls.py文件中的path和re_path1.path的基本规则:2.默认支持的转换器有:3.re_path正则匹配:Django中实战使用path和re_path1.url...
    99+
    2024-04-02
  • MyBatis框架零基础快速入门案例详解
    目录一、创建数据库和表二、创建maven工程三、代码编写1、编写Student实体类2、编写DAO接口StudentDao3、编写DAO接口Mapper映射文件StudentDao....
    99+
    2024-04-02
  • Java Map 入门指南:零基础轻松掌握集合框架的基础知识
    Java Map 简介 Java Map 是一个存储键值对的集合。键是唯一标识符,用于查找相应的值。值可以是任何类型的对象。Map 中的元素被称为键值对。键值对由键和值组成。键是键值对的唯一标识符,值是与键关联的数据。 Map 的不同实...
    99+
    2024-02-09
    Java Map 键值对 HashMap TreeMap LinkedHashMap
  • Python入门之基础语法详解
    目录一、我的经历及目标二、Python简介三、Python基础语法3.1行和缩进3.2Python注释3.3Python空行3.4同一行显示多条语句3.5print输出3.6多个语句...
    99+
    2024-04-02
  • C#中委托的基础入门与实现方法
    目录前言关于委托委托的实现一、基本实现方式二、使用委托时的一些特殊方式1、委托实例对象的创建多元化:2、事件绑定的多种方式三、委托的几种特殊实现方式1,使用Action方法2,使用F...
    99+
    2024-04-02
  • C语言入门之基础知识详解
    目录一、思维导图二、环境搭建三、编码规范四、基本数据类型五、分支循环5.1 分支5.2 循环六、break与continue6.1 无限循环一、思维导图 内容不限于此思维导图 二、...
    99+
    2024-04-02
  • Python编程入门基础语法详解
    一、基本概念内置的变量类型:Python是有变量类型的,而且会强制检查变量类型。内置的变量类型有如下几种:浮点float_number = 2.3复数complex_number = 1 + 5j整型integer_number = 1li...
    99+
    2023-06-02
  • C++11中std::function基础用法详解
    目录一、std::function基本介绍二、进阶使用方法2.1 与智能指针相结合2.2 存储成员函数指针2.3 存储std::bind三、注意tipsstd::function是C...
    99+
    2023-05-18
    C++11 std::function用法 C++11 std::function C++ std::function
  • C++中的map使用方法详解
    目录C++中的mapmap的介绍创建和初始化mapmap中的查找操作map的删除操作map的遍历操作在map中使用自定义比较器排序使用lower_bound()和upper_boun...
    99+
    2023-05-18
    C++ map使用 C++ map
  • C语言中map函数的基础用法是什么
    C语言中map函数的基础用法是什么,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。map有N个学生的姓名name和学号ID,要求给你一个学生的name求查找他的I...
    99+
    2023-06-22
  • Django零基础入门之静态文件的引用
    目录效果展示:1.静态文件引用:(1)创建静态文件目录:(2)静态文件路径的配置:(3)创建三大静态文件:(4)静态文件的引用:引言: 在我们Django中如何引用三大静态文件(Ja...
    99+
    2024-04-02
  • Vue零基础入门之模板语法与数据绑定及Object.defineProperty方法详解
    目录初识vue模板语法插值语法指令语法数据绑定单向绑定双向绑定el和data的两种写法eldataObject.defineProperty方法事件处理事件修饰符键盘事件定义命名(不...
    99+
    2024-04-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作