map的使用(c++)
在了解map之前,我们先看看两个场景,通过这两个场景的对比,让我们知道为什么要存在存储双关键字的容器
场景一:判断一堆字符串中,某一个字符串是否出现过
在没学set容器之前,我们只能想到把这一堆字符串存到一个字符型数组里面,从前往后遍历每一个字符,判断某一个字符串是否出现过,这个时间复杂度是O(N)级别的,如果我们学过set的话,我们就可以把这一堆字符串存到set容器里面,判断某一字符串是否出现过的时候直接调用里面的count接口就可以了,时间复杂度是O(logN)级别的,所以我们用set特解决场景一问题的时候,时间复杂是更优的
场景二:找出一堆字符串中,某一个字符串出现的次数
如果找的是次数,那么set容器就用不了了,set容器存储的是单关键字,而且里面是不能有重复元素的,大家可能想到有multiset,它可以存储重复的元素,因此要判断某一个字符串出现的次数,直接调用multiset里面的count不就完了吗?其实还有一个问题,如果这一堆字符串中,所有的字符全都长一样,比如有10,000个字符串里面的每个字符都是a,当我想找“aa”这个字符串出现的次数的时候,用multiset来解决的话是要遍历整个红黑树一遍的,要全部把它扫描一遍才能统计出a次数,此时它的时间复杂度是O(N)级别的,那和数组存储没有任何的差别,所以我们想判断某一个字符串出现的次数是不能用set容器的
此时存储双关键字的map就登场了,它可以做到存储双关键字,它把两个关键词绑定在一起,存到红黑树里面的,比如在这个问题里面,我想统计某一个字符串出现的字数,map绑定的两个关键字可以设置成,第一个是string第二个是int,它的意思是把字符串和出现的次数绑定在一起,放进红黑树里面的一个一个节点中,也就是说红黑树的节点存的是一个结构体,结构体的第一个关键字是字符串,第二个是字符串出现的次数,此时在查找某一个字符串出现的次数的时候,直接在这个红黑中找出对应的字符串,拿到它出现的次数就可以了,至于如何解决这样的一个问题,我们学完map的方式之后,在一起编写代码
map / multimap
map 与 multimap 的区别: map 不能存相同元素, multimap 可以存相同的元素,其余的使⽤⽅式完全⼀致。因此,这⾥只练习使⽤ map 。 map 与 set 的区别: set ⾥⾯存的是⼀个单独的关键字,也就是存⼀个 int 、 char 、 double 或者 string 。⽽ map ⾥⾯存的是⼀个 pair<key, value> ,(k-v 模型)不仅有⼀个关键字,还会有⼀个与关键字绑定的值,⽐较⽅式是按照 key 的值来⽐较。 也就是中序遍历的结果是按照第一个关键字的的大小来做比较的;可以这样理解:红⿊树⾥⾯⼀个⼀个的结点都是⼀个结构体,⾥⾯有两个元素分别是 key 和 value 。插⼊、删除和查找的过程中,⽐较的是 key 的值。
- 存 <int, int> ,来统计数字出现的次数;
- 存 <string, int> ,来统计字符串出现的次数;
- 存 <string, string> ,表⽰⼀个字符串变成另⼀个字符串;
- 甚⾄存 <int, vector<int>> 来表⽰⼀个数后⾯跟了若⼲个数......,可以用来存储树,就是一个根结点,后面跟了一堆孩子,int表示根,vector<int>存它的一堆孩子,但用map存储树的效率不高,因为查找的时间复杂是O(logN),后面我们在学习哈希表的时候,可以给大家演示一下如何用这个东西存储树,因为用哈希表来存储这样的形式,查找是很快的
1 创建 map
#include <iostream>
#include <vector>
#include <map>
using namespace std;
int main()
{ map<int, int> mp1; map<int, string> mp2; map<string, int> mp3; map<int, vector<int>> mp4; // 甚⾄可以挂⼀个 vectorreturn 0;
}
2 size / empty
- size :求红⿊树的⼤⼩。时间复杂度: O(1) 。
- empty :判断红⿊树是否为空。时间复杂度: O(1) 。
3 begin / end
- 迭代器,可以使⽤范围 for 遍历整个红⿊树。
- 遍历是按照中序遍历的顺序,因此是⼀个有序的序列。
4 insert
- 向红⿊树中插⼊⼀个元素。这⾥需要插⼊⼀个 pair,可以⽤ {} 形式。⽐如: mp.insert({1, 2}) 。时间复杂度: O(log N) 。
5 operator []
- 重载 [] ,使得 map 可以像数组⼀样使⽤。
- 这是 map 最好⽤的接⼝,有了这个重载,map 的使⽤就变得特别轻松,不⽤写很多冗余的代码。
- 它的底层其实就是调⽤了 insert 函数,并且会返回 val 的引⽤。我们⽬前就先学会使⽤即可。
6 erase
- 删除⼀个元素。时间复杂度: O(log N) 。
7 find / count
- find :查找⼀个元素,返回的是迭代器。时间复杂度: O(log N) 。
- count :查询元素出现的次数,⼀般⽤来判断当前元素是否在红⿊树中。时间复杂度:O(log N) 。
8 lower_bound / upper_bound
- lower_bound :⼤于等于 x 的最⼩元素,返回的是迭代器。时间复杂度: O(log N) 。
- upper_bound :⼤于 x 的最⼩元素,返回的是迭代器。时间复杂度: O(log N) 。
代码:
#include <iostream>
#include <map>
#include <string>
using namespace std;//传引用使得mp不需要拷贝
void print(map<string, int>& mp)
{//&避免拷贝//双关键字用auto提取出来的是一个pair类型,所以打印要用first、secondfor (auto& p : mp){cout << p.first << " " << p.second << endl;}
}void test1()
{map<string, int> mp;//插入mp.insert({ "张三", 1 });mp.insert({ "李四", 2 });mp.insert({ "王五", 3 });print(mp); //打印出来的结果按第一个关键字作比较,后面的关键字只起到绑定作用//李四 2//王五 3//张三 1//operator[] 可以让 map 像数组一样使用int a[2] = { 1,2 };a[1] = 4;cout << a[1] << endl; //4cout << mp["张三"] << endl; //1mp["张三"] = 110;cout << mp["张三"] << endl; //110// 注意事项:operator[] 有可能会向 map 中插入本不想插入的元素if (mp["赵六"] == 4) cout << "yes";else cout << "no" << endl; //no//虽然我们只是想判断赵六存不存在,但是一旦调用了[],就把赵六插入进来了// [] 里面的内容如果不存在 map 中,会先插入,然后再拿值// 插入的时候:第一个关键字就是 [] 里面的内容,第二个关键字是一个默认值print(mp);//李四 2//王五 3//张三 110//赵六 0//这样的逻辑去写就没有插入张飞,从mp.count("张飞")这句话就断掉了//后面的语句没有执行了,此时打印张飞是不存在map里的if (mp.count("张飞") && mp["赵六"] == 4) cout << "yes" << endl;else cout << "no" << endl; //noprint(mp);cout << endl;//李四 2//王五 3//张三 110//赵六 0//删除mp.erase("张三");print(mp);cout << endl;//李四 2//王五 3//赵六 0//auto x = mp.lower_bound("李四");map<string, int>::iterator x = mp.lower_bound("李四");cout << x->first << " " << x->second << endl; //李四x = mp.upper_bound("李四");cout << x->first << " " << x->second << endl; //王五
}// 统计一堆字符串中,每一个字符串出现的次数
void fun()
{string s;map<string, int> mp; // <字符串,字符串出现的次数>for (int i = 1; i <= 5; i++){cin >> s;mp[s]++; // 体现了 operator 的强大,s字符串不存在会先插入 }print(mp);//输入//sdf//aa//dd//aa//dd//输出//aa 2//dd 2//sdf 1
}int main()
{test1();//fun();return 0;
}
相关文章:
map的使用(c++)
在了解map之前,我们先看看两个场景,通过这两个场景的对比,让我们知道为什么要存在存储双关键字的容器 场景一:判断一堆字符串中,某一个字符串是否出现过 在没学set容器之前,我们只能想到把这一堆字符串存到…...
毕业设计—基于Spring Boot的社区居民健康管理平台的设计与实现
🎓 毕业设计大揭秘!想要源码和文章?快来私信我吧! Hey小伙伴们~ 👋 毕业季又来啦!是不是都在为毕业设计忙得团团转呢?🤔 别担心,我这里有个小小的福利要分享给你们哦&…...
Python:蟒蛇绘制(一笔画)
一、题目要求 使用turtle库,绘制一个蟒蛇形状的图形。 二、代码展示 # 请在下方开始编写你的代码 import turtle turtle.setup(650,350,200,200) turtle.penup() turtle.fd(-250) turtle.pendown() turtle.pensize(25) turtle.pencolor("purple") turt…...
mysql查询判断函数,类似decode
mysql中没有decode函数,如果使用的话,会报如下错误:Error Code: 1305. FUNCTION stockdb.decode does not exist 如果要实现像 Oracle 数据库那样原生的 DECODE 函数,可以通过以下几种方式来实现类似 DECODE 函数的功能。 -- 创建…...
异常处理、事务管理
异常处理 程序开发过程中不可避免的会遇到异常现象 如何处理 方案一:在Controller的方法中进行try...catch处理(代码臃肿,不推荐) 方案二:全局异常处理器 全局异常处理器 RestControllerAdvice :定义全…...
UART(一)——UART基础
一、定义 UART(Universal Asynchronous Receiver/Transmitter)是一种广泛使用的串行通信协议,用于在设备间通过异步方式传输数据。它无需共享时钟信号,而是依赖双方预先约定的参数(如波特率)完成通信。 功能和特点 基本的 UART 系统只需三个信号即可提供稳健的中速全双工…...
MySQL 中各种日志简介
MySQL 日志 慢查询日志(Slow query log) 慢查询⽇志由执⾏时间超过系统变量 long_query_time 指定的秒数的SQL语句组成,并且检 查的⾏数⼤于系统变量 min_examined_row_limit 指定值。被记录的慢查询需要进⾏优化, 可以使⽤mysqldumpslow客⼾端程序对慢…...
【每日论文】Text-guided Sparse Voxel Pruning for Efficient 3D Visual Grounding
下载PDF或者阅读论文,请点击查看:LlamaFactory - huggingface daily paper - 每日论文解读 | LlamaFactory | LlamaFactory 摘要 中文 在这篇论文中,我们提出了一种高效的多级卷积架构,用于3D视觉定位。传统的由于采用两阶段或基…...
Kylin server v10部署docker
这里不用写什么标题 1. docker环境1.1 docker-ce1.1.1 yum安装1.1.2 离线安装 1.2 docker-compose 2. 镜像载入3. 服务启停4. 其他 1. docker环境 1.1 docker-ce docker-ce是社区版docker服务,可以通过yum方式直接安装或者离线安装,在国产化环境中&…...
计算机之就业主流岗(Mainstream Computer Employment Positions)
计算机之就业主流岗 计算机行业一直以来都是就业市场中的热门领域,技术岗位种类繁多,但每个岗位都有自己的核心技能和职责方向。以下是计算机行业中主流的技术岗位及其特点介绍,帮助你更清晰地了解这些职业的内容和发展前景。 1. 后端开发 …...
DeepSeek 助力 Vue 开发:打造丝滑的日期选择器(Date Picker),未使用第三方插件
前言:哈喽,大家好,今天给大家分享一篇文章!并提供具体代码帮助大家深入理解,彻底掌握!创作不易,如果能帮助到大家或者给大家一些灵感和启发,欢迎收藏关注哦 💕 目录 Deep…...
【Mac技巧】添加DNS解析到hosts文件
【Mac技巧】添加DNS解析到hosts文件 Add DNS Resolution to hosts on Mac 我们通常访问一个Web站点(即网址),需要输入网址关键字(例如: 太平洋汽车网),或者输入pcauto.com.cn即可。 这期间仅…...
【批判性思维有什么用?】
1.批判性思维,指的是在人格平等的状态下,对自己和他人观点做谨慎多角度地思考。它讲究逻辑和理性,是一种高效地积累知识的方法。 2.只有那些我们完全不熟悉的结论和我们已经熟悉得不能再熟悉的结论,对它们的反思,才能…...
Golang学习笔记_34——组合模式
Golang学习笔记_31——原型模式 Golang学习笔记_32——适配器模式 Golang学习笔记_33——桥接模式 文章目录 一、核心概念1. 定义2. 解决的问题3. 核心角色4. 类图 二、特点分析三、适用场景1. 文件系统2. 图形界面3. 组织架构 四、代码示例(Go语言)五、…...
以太网详解(八)传输层协议:TCP/UDP 协议
文章目录 传输层协议概述为什么需要传输层?传输层功能网络层与传输层在实现 “端到端” 传输的异同两类服务:面向连接/无连接服务 传输控制协议 TCPTCP 协议数据单元格式TCP 的重传机制快重传和快恢复快重传举例快恢复算法 用户数据报协议 UDPUDP 概述UDP 基本工作过…...
基于Spark抖音评论舆情分析系统
✔️情绪分析、文本挖掘、文本分类,词频统计、情感分析,词云制作,词语共现网络图、人物关系网络建立等 ✔️主营:指导解答anaconda、python数据分析、数据挖掘、词频统计、词云、情感分析、python机器学习、Flask Django web、jup…...
JAVA系列之数组的秘密(数组的一般用法+力扣 斯坦福大学练习精解)
大佬们好呀~ 更多精彩: 个人主页 JAVA专栏 文章目录 一、数组的概述1.1什么是数组?1.2注意:1.3建议: 二、数组的定义1.格式: 三、数组的静态初始化1.数组的初始化:2.静态初始化:格式:数组的长度:…...
探索飞鹤奶粉奥秘,领会科技魅力
在科技迅猛发展的当下,AI 技术正深刻重塑各行业格局。乳制品行业亦不例外。近日,长江商学院「AI 未来空间站」的同学们深入走访了飞鹤集团,探寻其在数字化浪潮中的创新实践与卓越成就。 在飞鹤的智能化生产车间,同学们目睹了高度自…...
【数据仓库】StarRocks docker部署
StarRocks docker部署 一、环境准备安装 docker 及 docker-compose操作系统相关禁用及配置【CentOS Linux 7 (Core)】 二、StarRocks-v2.5【存算一体,3FE,3BE】BE节点配置FE节点配置服务启动BE节点添加FE 节点添加 三、监控(待完善)四、VIP Nginx Keepalived(待完善)五、Star…...
Java虚拟机面试题:内存管理(下)
🧑 博主简介:CSDN博客专家,历代文学网(PC端可以访问:https://literature.sinhy.com/#/?__c1000,移动端可微信小程序搜索“历代文学”)总架构师,15年工作经验,精通Java编…...
解决方案:Umi-OCR批量处理性能提升40%的架构优化指南
解决方案:Umi-OCR批量处理性能提升40%的架构优化指南 【免费下载链接】Umi-OCR OCR software, free and offline. 开源、免费的离线OCR软件。支持截屏/批量导入图片,PDF文档识别,排除水印/页眉页脚,扫描/生成二维码。内置多国语言…...
从“推”到“挽”:三极管推挽电路在Arduino电机驱动中的实战应用(含代码)
从“推”到“挽”:三极管推挽电路在Arduino电机驱动中的实战应用(含代码) 当你用Arduino控制直流电机时,是否遇到过IO口驱动能力不足的困扰?普通数字引脚仅能提供20mA左右的电流,而即便是小型直流电机&…...
爬虫工程师必备:claw-shield框架深度解析与实战指南
1. 项目概述:一个为爬虫工程师打造的“盾牌”最近在和一些做数据采集的朋友交流时,大家普遍提到一个痛点:随着目标网站反爬策略的日益复杂和严厉,维护一个稳定、高效的爬虫系统变得越来越像一场“军备竞赛”。你刚搞定一个验证码&…...
2026年梧州引流获客品牌口碑百科与客观解读
在2026年的梧州,实体门店面临的获客挑战已从“要不要做线上”转变为“如何低成本、高效率地做线上”。本地商家普遍反映,线下客流萎缩、线上投入不见产出,尤其对于美容、教培、制造业、餐饮及实体零售等行业的经营者,试错成本高、…...
保姆级教程:手把手复现AGPCNet红外小目标检测(附PyTorch源码与数据集)
从零实现AGPCNet:红外小目标检测实战指南与PyTorch源码精解 红外小目标检测在军事侦察、安防监控等领域具有重要应用价值,但传统方法常受限于目标尺寸小、信噪比低等挑战。AGPCNet通过注意力引导的金字塔上下文网络架构,在保持高精度的同时显…...
解锁B站缓存视频:m4s-converter让你的收藏永不消失
解锁B站缓存视频:m4s-converter让你的收藏永不消失 【免费下载链接】m4s-converter 一个跨平台小工具,将bilibili缓存的m4s格式音视频文件合并成mp4 项目地址: https://gitcode.com/gh_mirrors/m4/m4s-converter 你是否遇到过精心收藏的B站视频突…...
论MY SQL打击犯罪集团攻击的指导要义
使用 **MySQL Installer** 安装 MySQL Community Edition,界面停留在 “Choosing a Setup Type”(选择安装类型)步骤。这是安装过程中非常关键的一步,它决定了你将安装哪些组件、占用多少磁盘空间、以及后续能做什么操作。下面我为…...
从VIP源码到你的Testbench:深入解读Synopsys AXI验证IP的常量定义机制
从VIP源码到你的Testbench:深入解读Synopsys AXI验证IP的常量定义机制 在芯片验证领域,Synopsys的验证IP(VIP)就像一位经验丰富的向导,带领我们穿越复杂的协议迷宫。但真正的高手从不满足于跟随向导的脚步,而是渴望理解向导手中的…...
保姆级教程:用STM32CubeMX+TouchGFX Designer给F429驱动RGB屏(附SDRAM配置避坑)
从零开始构建STM32F429的TouchGFX图形界面:CubeMX配置与实战避坑指南 第一次拿到STM32F429开发板和RGB屏幕时,那种既兴奋又忐忑的心情至今记忆犹新。兴奋的是终于可以开始图形界面开发,忐忑的是网上教程要么过于简略,要么假设读者…...
终极指南:如何用Sunshine自建游戏串流服务器,让低配设备畅玩3A大作
终极指南:如何用Sunshine自建游戏串流服务器,让低配设备畅玩3A大作 【免费下载链接】Sunshine Self-hosted game stream host for Moonlight. 项目地址: https://gitcode.com/GitHub_Trending/su/Sunshine Sunshine是一款强大的开源游戏串流服务器…...
