【C++取经之路】map的详细介绍及其使用

news2025/1/10 2:10:08

目录

关于map

键值对

map的常用操作

关于multimap


关于map

template < class Key,                                     // map::key_type
           class T,                                       // map::mapped_type
           class Compare = less<Key>,                     // map::key_compare
           class Alloc = allocator<pair<const Key,T> >    // map::allocator_type
           > class map;

map是一种关联式容器,里面存的是<key,val>这样的键值对。map中,key是不允许修改的,它总是const,而且key是唯一的,不允许重复。所以当map中已经存在这样的键值对——<密码,"123456">,我们再插入<密码,"654321">时,会导致插入失败。这种场景需要multimap,讲完map后会提到multimap,到时我们在细说。map的底层是基于红黑树实现的,同时它要求key要能够进行<的比较,map默认情况下就是按照小于来比较的。

键值对

用来表示具有一一对应关系的一种结构,该变量中一般只包含两个成员变量key和value,key代表键值,value表示与key对应的信息。例如上面提到的<密码,"123456">就是一个键值对。这里顺便提一下,有一个指向map中的元素的迭代器,如何通过迭代器去访问value。iterator->first,访问到的是key,iterator->second,访问到的是value。

map的常用操作

insert

pair<iterator,bool> insert (const value_type& val); 说明一下,val_type是 pair<const key_type,mapped_type>的别名

插入单个元素或者说是插入单个pair。

iterator insert (iterator position, const value_type& val);

指定位置插入单个val,明面上是说在指定位置插入,其实暗地里还是按照搜索树的规则来进行插入。

void insert (InputIterator first, InputIterator last);

迭代器区间插入。

如果读者对set有所了解,那么学习map的成本一定不高,这得益于STL的设计。

#include <map>
#include <string>

int main()
{
	map<string, string> mp1;
	mp1.insert({ "left", "左边" });				//插入单个val
	mp1.insert(mp1.begin(), { "right", "右边" });//指定位置插入

	return 0;
}

begin()            返回指向第一个元素的迭代器

end()               返回指向理论元素的迭代器,这个元素在最后一个元素后面(下面解释)

rbegin()           返回指向最后一个元素的迭代器

rend()              返回指向理论元素的迭代器,这个元素在首元素前

empty()           如果map为空,返回true,否则返回false

size()               返回map中元素的个数

clear()              清空map中的所有元素,size置为0

count(x)           返回键值为x的元素的个数               

find()                找到返回指向对应元素的迭代器,否则返回end()

理论元素这个名词是出自文档的,我只是知识的搬运工。其实这个底层的红黑树的设计有关。大概是这样子的:

它有一个哨兵位结点(上方的),两边的就是理论元素了。 

#include <iostream>
#include <map>
using namespace std;

int main()
{
	map<char, int> mp;
	mp.insert({ 'a', 0 });
	mp.insert({ 'b', 1 });

	cout << "mp中元素个数为:" << mp.size() << endl;
	cout << "mp中的首元素为:" << mp.begin()->second << endl;
	cout << "mp中键值为c的元素个数:" << mp.count('c') << endl;
	cout << endl << "清空mp中的所有元素" << endl;
	mp.clear();
	cout << "mp中元素个数为:" << mp.size() << endl;

	return 0;
}

运行结果:
mp中元素个数为:2
mp中的首元素为:0
mp中键值为c的元素个数:0

清空mp中的所有元素
mp中元素个数为:0

erase

void erase (iterator position);                 删除指定位置的值

size_type erase (const key_type& k);    删除键值为k的值,并返回删除的元素个数

void erase (iterator first, iterator last);   删除迭代器区间中的值

#include <iostream>
#include <map>
using namespace std;

int main()
{
	map<char, int> mp;
	mp.insert({ 'a', 0 });
	mp.insert({ 'b', 1 });
	mp.insert({ 'c', 2 });
	mp.insert({ 'd', 3 });
	mp.insert({ 'e', 4 });

	cout << "mp中元素个数为:" << mp.size() << endl;
	mp.erase('a');          //删除键值为a的元素
	cout << "erase('a')" << endl;
	cout << "mp中元素个数为:" << mp.size() << endl << endl;

	mp.erase(mp.begin());   //删除指定位置的元素
	cout << "mp.erase(mp.begin())" << endl;
	cout << "mp中元素个数为:" << mp.size() << endl << endl;

	map<char, int>::iterator first = mp.begin();
	map<char, int>::iterator second = first;
	second++;
	second++;

	mp.erase(first, second);//删除迭代器区间中的元素
	cout << "mp.erase(first, second):" << endl;
	cout << "mp中元素个数为:" << mp.size() << endl;

	return 0;
}

运行结果:
mp中元素个数为:5
erase('a')
mp中元素个数为:4

mp.erase(mp.begin())
mp中元素个数为:3

mp.erase(first, second):
mp中元素个数为:1

operator[ ] 

operator[key],如果key存在,返回key所对应的value,如果不存在,则进行插入(调用value的默认构造)并返回对应的value。

operator[key] = new_val;如果key存在,它的value更新为new_val,如果不存在,相当于插入{ key, new_val }。总之,就是key存在,就更新它对应的value,key不存在,就插入。

#include <iostream>
#include <map>
using namespace std;

int main()
{
	map<char, int> mp;
	mp.insert({ 'a', 0 });
	mp.insert({ 'b', 1 });
	mp.insert({ 'c', 2 });
	mp.insert({ 'd', 3 });
	mp.insert({ 'e', 4 });

	mp['a'] = 10;//a存在,对应的val更新为10
	mp['f'] = 6; //f不存在,插入{'f', 6}

	cout << "a对应的value:" << mp['a'] << endl;
	cout << "f对应的value:" << mp['f'] << endl;

	return 0;
}

运行结果:
a对应的value:10
f对应的value:6

关于multimap

multimap和map一样,都是关联式容器,他们俩唯一的区别就是:map中的键值key是唯一的,而multimap中的可以不唯一,可以重复。在用法上,multimap没用重载operator[ ],因为有重复的key,每个相同的key对应的信息不一样,到底要返回哪一个?返回不明确,所以multimap没有重载operator[ ]。


本篇文章到这就结束啦,感谢你的支持!  想了解set的读者可以参考这篇博客哦~【C++取经之路】set的详细介绍及其使用-CSDN博客

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2108952.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

【时间盒子】-【5.绘制闹钟】动态绘制钟表和数字时间

Tips: Preview装饰器&#xff0c;支持组件可预览&#xff1b; Component装饰器&#xff0c;自定义组件&#xff1b; Canvas组件的使用&#xff1b; 使用RenderingContext在Canvas组件上绘制图形&#xff0c;请参考官方文档&#xff1a;https://developer.huawei.com/consume…

Apache ShardingSphere数据分片弹性伸缩加解密中间件

Apache ShardingSphere Apache ShardingSphere 是一款分布式 SQL 事务和查询引擎,可通过数据分片、弹性伸缩、加密等能力对任意数据库进行增强。 软件背景 ShardingSphere是一套开源的分布式数据库中间件解决方案组成的生态圈,它由Sharding-JDBC、Sharding-Proxy和Sharding…

如何利用python实现碰撞原理

先看图 跑了大概一天 这是结果 具体是通过BIP39规则生成的种子数据 生成完词组后&#xff0c;再根据词组生成姨太地址 # 生成随机助记词 def generate_mnemonic():entropy os.urandom(16) # 随机生成 16 字节熵mnemonic []for i in range(12): # 生成 12 个助记词word_in…

欧拉数据库的搭建及其部署

数据库的搭建 进行数据库安装前&#xff0c;必须保证软件yum仓库搭建完成 使用命令 dnf install mariadb-server&#xff0c;发现冲突selinux-policy-targeted-35.5-21.oe2203sp3.noarch有问题 [rootlocalhost yum.repos.d]# dnf install mariadb-server [rootlocalhost y…

Arthas工具使用,分析线上问题好帮手

在K8S中的步骤&#xff1a; #1.进入node #2.下载arthas 在容器中下载并启动 Arthas&#xff1a; java -jar arthas-boot.jar --repo-mirror aliyun --use-http #3.找到出现问题的类和方法的绝对路径 类路径 方法 #4.执行trace命令或者watch命令 trace:命令会追踪方法的执…

电脑硬盘数据丢失了怎么恢复?简单实用的硬盘数据找回的方法

我们的电脑使用硬盘作为存储设备来保存数据&#xff0c;硬盘里的数据是存储在扇区上&#xff0c;这些存储数据的单元则位于表面有磁性材料的旋转的盘片上。硬盘内部的磁头悬浮于高速旋转的盘片上&#xff0c;用于读写和检索数据。 假如我们使用电脑时不小心删除了某个文件&…

iOS——weak修饰符的学习补充

Weak修饰符的内部机制 SideTable ObjectC中对对象的存储&#xff0c;实现上做了一定的优化&#xff0c;一旦有弱引用对象被赋值&#xff0c;即运行时&#xff08;Runtime&#xff09;会在全局的SideTables中分配一个SideTable空间&#xff0c;此空间是根据对象的地址相关算法…

多线程 | synchronized的底层原理

目录 1.它做了什么2.什么是Monitor如何减少用户态和内核态的切换 3.对象头和内置锁 (ObjectMonitor)3.1对象头3.2内置锁 (ObjectMonitor)3.3wait方法底层3.4notify 方法的底层实现 4.总结 1.它做了什么 使用synchronized的修饰的代码块如下&#xff0c;那么jvm是如何编译它的&…

【PyQt6 应用程序】短剧原视频直接生成解说视频精简版

在当今视频内容创作日益繁荣的时代,利用自动化工具进行视频编辑和二次创作已成为提高生产效率和创作水平的重要手段。本文将介绍如何使用PyQt6创建一个应用程序,该程序能够自动提取视频中的解说和原声部分,并使用人工智能生成配套的解说视频,从而生成具有独特风格的新视频内…

Oracle OCP认证值得考吗? 需要门槛吗?

随着数据量的爆炸性增长和企业对数据依赖性的提升&#xff0c;对数据库专业人士的需求也在不断上升。OCP认证&#xff0c;作为Oracle公司提供的权威认证之一&#xff0c;长期以来被视为数据库专业人士技能和知识水平的重要标志。 但随着技术的发展和认证种类的增多&#xff0c;…

基于百度AIStudio飞桨paddleRS-develop版道路模型开发训练

基于百度AIStudio飞桨paddleRS-develop版道路模型开发训练 参考地址&#xff1a;https://aistudio.baidu.com/projectdetail/8271882 基于python35paddle120env环境 预测可视化结果&#xff1a; &#xff08;一&#xff09;安装环境&#xff1a; 先上传本地下载的源代码Pad…

数据分析:R语言计算XGBoost线性回归模型的SHAP值

禁止商业或二改转载,仅供自学使用,侵权必究,如需截取部分内容请后台联系作者! 文章目录 介绍SHAP用途计算方法:应用加载R包导入数据数据预处理函数模型介绍 SHAP(SHapley Additive exPlanations)值是一种解释机器学习模型预测的方法。它基于博弈论中的Shapley值概念,…

Linux高性能服务器编程 总结索引 | 第3章:TCP协议详解

和IP协议相比&#xff0c;TCP协议 更靠近应用层&#xff0c;因此在应用程序中具有 更强的可操作性。一些重要的socket选项都和TCP协议相关 TCP头部信息。TCP头部信息出现在 每个TCP报文段中&#xff0c;用于指定 通信的源端口号、目的端口号&#xff0c;管理TCP连接&#xff0…

使用ffmpeg在视频中绘制矩形区域

由于项目需要对视频中的人脸做定位跟踪&#xff0c; 我先使用了人脸识别算法&#xff0c;对视频中的每个帧识别人脸、通过人脸库比对&#xff0c;最终记录坐标等信息。 然后使用ffmpeg中的 drawbox 滤镜功能&#xff0c;选择性的绘制区域。从而实现人脸定位跟踪 1、drawbox …

C++项目引入开源库bit7z

摘要&#xff1a; 公司C项目需要能解压缩.tar文件&#xff0c;关键是要在Windows环境下&#xff0c;tar格式主要是Linux中用的压缩文件&#xff0c;还要考虑到用户可能没有Windows自带的tar命令&#xff0c;最终解决方案就是一步到位&#xff0c;考虑到后续的功能拓展引入第三方…

尚品汇-延迟插件实现订单超时取消(四十五)

目录&#xff1a; &#xff08;1&#xff09;延迟插件封装 &#xff08;2&#xff09;基于延迟插件测试 如何保证消息幂等性&#xff1f; &#xff08;3&#xff09;改造订单service-order模块-实现订单超时取消 &#xff08;1&#xff09;延迟插件封装 把消息带过去&#…

computed计算属性及方法对比和循环遍历统计以及watch和watchEect监听的用法

1.computed计算属性及方法对比 1.了解computed计算属性和用法 在我们的一些应用中可以看的应用会给我们提供一些计算类的功能比如取名&#xff0c;它会给你提供两个输入框&#xff0c;然后在你给这两个输入框输入值的时候会在下方生成你输入这个两个值的结合值&#xff0c;就…

Java使用类加载器解决类冲突,多版本jar共存

Java使用类加载器解决类冲突 1、案例说明2、打包新版本POI并将要调用的方法封装2.1、POM文件2.2、封装的方法 3、要使用多个POI版本的项目3.1、打包前面的项目生成一个jar包3.1、POM文件3.2、类加载器代码3.3、Jar加载工具3.4、最终调用 1、案例说明 项目中已经有了一个旧版本…

【后端开发】PHP、go语言、Java、C++、Linux开发等急招中......

本周高薪急招后端开发岗位推荐&#xff0c;PHP、go语言、Java、C、Linux开发等岗位都在热招&#xff0c;月薪最高35K&#xff0c;还不快来&#xff01;&#xff01; 抓紧投递&#xff0c;早投早入职&#xff01; &#x1f447;点击职位名称查看详情&#x1f447; PHP 薪资&…

Leetcode每日刷题之102.二叉树的层序遍历

1.题目解析 本题是关于二叉树的层序遍历&#xff0c;不过这里的难点是如何将每一层的数据存储在数组并将整体存储在一个二维数组中&#xff0c;具体的算法原理我们在下面给出 2.算法原理 关于将每层数据分别存储在不同数组中&#xff0c;我们可以定义一个levelSize变量来存储栈…