STL-map和set
目录
一、关联式容器
二、键值对
三、树形结构的关联式容器
3.1 set
3.1.1 set介绍
3.1.2 set的使用
1. set的模板参数列表
2. set的构造
3. set的迭代器(类型是双向迭代器)
4. set的容量
5.set修改操作
6、operator
7. set的使用举例
3.2 map
3.2.1map介绍
3.2.2map的使用
1.map的模板参数说明
2. map的构造
编辑
3. map的迭代器(类其他容器)
4. map的容量与元素访问
5. map中元素的修改
6、operator编辑
3.3 multiset
3.3.1 multiset的介绍
3.4 multimap
3.4.1 multimap的介绍
3.4.2 multimap的使用
3.5 在OJ中的使用
一、关联式容器
一般我们之前所学习的vector、list、daque、forword_list(C++11)等容器,都是序列式容器,因为底层是线性序列的数据结构,里面存储的是元素本身。
关联式容器也是存储型容器,但是与序列式容器不同的是,关联式容器一般存储的是键值对——<key,value>,在数据检索时比序列式容器雄效率更高。
二、键值对
一种类或者结构体,用来表述具有一一对应关系的两个值,一般存在两个成员变量key和value,key表示键值,用与检索,比较,排序,value表示key对应的数据或信息。
例如:建立一个汉英对应的字典,每一个英文单词都有对应的中文含义,将英文单词作为key值,value作为对应的中文含义,英文单词与中文含义是一一对应的关系,在此字典中,即可以通过英文找到其中文含义。
SGI-STL中关于键值对的定义
template<class T1,class T2> struct pair{typedef T1 first_type;typedef T2 second_type;T1 first;T2 second;pair():first(T1()),second(T2()){}pair(const T1& a, const T2& b):first(T1()),second(T2()){} }
三、树形结构的关联式容器
根据应用场景的不同,STL总共实现了两种不同结构的管理式容器:树型结构和哈希结构。树型结构的关联式容器主要有四种:map,set,multimap,multiset。这四种容器的特点是都使用了平衡搜索二叉树(红黑树)作为其底层结果,容器中的元素是一个有序的序列(key值排序)。下面依次介绍每一个容器。
3.1 set
3.1.1 set介绍
set文档
翻译:
1、set是按照一定次序存储元素
2、在set中,value与key相同,即是唯一的,key不可修改,但是可以插入或者删除
3、在内部,set中的元素总是按照其内部比较对象(类型比较)所指示的特定严格弱排序准则进行排序
4. set容器通过key访问单个元素的速度通常比unordered_set容器慢,但它们允许根据顺序对 子集进行直接迭代。
5. set在底层是用二叉搜索树(红黑树)实现的
注意:
1. 与map/multimap不同,map/multimap中存储的是真正的键值对,set中只放 value,但在底层实际存放的是由构成的键值对<value,value>。
2. set中插入元素时,只需要插入value即可,不需要构造键值对。
3. set中的元素不可以重复(因此可以使用set进行去重)。
4. 使用set的迭代器遍历set中的元素,可以得到有序序列
5. set中的元素默认按照小于来比较 6. set中查找某个元素,时间复杂度为:$log_2 n$ 7. set中的元素不允许修改(为什么?)
8. set中的底层使用二叉搜索树(红黑树)来实现。
3.1.2 set的使用
1. set的模板参数列表
T: set中存放元素的类型,实际在底层存储的键值对。
Compare:set中元素默认按照小于来比较(升序)
Alloc:set中元素空间的管理方式,使用STL提供的空间配置器管理
2. set的构造
按参数列表分类:默认构造、按迭代器范围构造、拷贝构造
3. set的迭代器(类型是双向迭代器)
4. set的容量
5.set修改操作
声明:
重点:在set中插入元素x,实际插入的是<x,x>构成的键值对,如果插入成功,返回<该元素在set中的位置,true>,如果插入失败,说明x在set中已经存在返回<x在set中的位置,false>
value_type是类模板中的第一个参数的别名
声明:
(1)删除位置上的元素 (3)删除迭代器范围的元素 (2)删除值为val的元素,并返回哥数
声明:
交换两个set中的元素
声明:
清空元素
6、operator
- find:传递key,返回指向位置的迭代器,count():传递key,返回个数,(set中仅有一哥元素)
- lower_bound:传递key,返回在set序列中的第一个元素位置的迭代器,
- upper_bound:传递key,返回在set序列中的最后一个元素的下一个位置的迭代器, 上述两函数实现左闭右开区级,满足函数区间需求。
- equal_range:转递key,返回该元素区间边界的迭代器组成的一个键值对,第一个是lower_bound,第二个是upper_bound.
7. set的使用举例
#include<set> #include<iostream> #include<set> using std::cout; using std::endl; using std::set; void test() {int array[] = { 1,1,1,1,1,3,1,23,3,3,2,13,2,23,3,23,3,1,2,1,1,2,1,2,567,5,7,6,5 };set<int> s(array, array + sizeof(array) / sizeof(array[0]));cout << s.size() << endl;for (int e : s){cout << e << " ";}cout << endl;//逆向打印for (set<int>::reverse_iterator it = s.rbegin(); it != s.rend(); it++){cout << *it << " ";}cout << endl;//统计次数cout << s.count(3) << endl; }int main() {test();return 0; }
3.2 map
3.2.1map介绍
map文档
翻译:
1、map是关联容器,它按照特定的次序(按照key来比较)存储由键值key和值value组合而成的元素
2、在map中,键值key通常用于排序和唯一的标识元素,用于find查找,value中存储与key关联的内容。键值key和值value的类型可能不同,并且在map的内部,key与value通过成员类型value_type绑定到一起,其为pair类实例化取别名。
typedef pair<const key,T> value_type;
3、在内部,map中的元素是按照键值key来比较排序,
4、map中通过键值访问单一元素通常比unorder_map容器慢,但map允许对元素进行直接迭代,也就是说可以遍历访问,得到一个有序序列。
5、map支持下标访问符,即在[]中放入key,可以直接找到与key对应都的value
6、map通常底层实现为平衡二叉树,即红黑树
3.2.2map的使用
1.map的模板参数说明
key对应键值类型,
T对应value类型,
compare比较器的类型,缺省按找小于比较,升序序列,一般情况下(内置类型元素)该参数不需要传递,如果无法比较时(自定义类型),需要用户自己显示传递比较规则(一般情况下按照函数指针或者仿函数来传递)
Alloc:通过空间配置器来申请底层空间,不需要用户传递,除非用户不想使用标准库提供的 空间配置器
2. map的构造
空参数列表构造,迭代器范围构造、拷贝构造
3. map的迭代器(类其他容器)
4. map的容量与元素访问
- empty:无参,空返回true,否则返回false
- size:无参,返回元素个数
- operator[]:参数是键值key,返回value的引用
注意:如果键值key在map中不存在,则插入一个新的键值对元素,键值为key,value的值为对应类型的默认构造。
- at():同operator[]
5. map中元素的修改
- insert:参数为键值对(pair类型),返回一个键值对,键值对first为插入位置(类型iterator),second为bool类型,表示插入是否成功。
- erase:①参数为元素位置,返回void,②参数为迭代器范围,删除范围中的元素
- swap:交换两个map中的元素,this*与参数交换,参数为map类型,返回void
- clear:清空map
6、operator
- find:找键值key的位置,参数为键值key,返回位置迭代器
- count:参数为key,返回键值key的个数,为1或0
- lower_bound:参数为key,返回第一个key的位置迭代器
- upper_bound:参数为key,返回最后一个key的下一个位置迭代器
- equal_bound:参数为key,返回键值对,类型为pair<map<key,value>::iterator,map<key,value>::iterator>,first为第一个key的位置迭代器,second是最后一个key的下一个位置迭代器
【总结】
1. map中的的元素是键值对
2. map中的key是唯一的,并且不能修改
3. 默认按照小于的方式对key进行比较
4. map中的元素如果用迭代器去遍历,可以得到一个有序的序列
5. map的底层为平衡搜索树(红黑树),查找效率比较高$O(log_2 N)$
6. 支持[]操作符,operator[]中实际进行插入查找
3.3 multiset
3.3.1 multiset的介绍
[翻译]:
1. multiset是按照特定顺序存储元素的容器,其中元素是可以重复的。(与set的区别)
2. 在multiset中,元素的value也会识别它(因为multiset中本身存储的就是组成 的键值对,因此value本身就是key,key就是value,类型为T). multiset元素的值不能在容器中进行修改(因为元素总是const的),但可以从容器中插入或删除。
3. 在内部,multiset中的元素总是按照其内部比较规则(类型比较)所指示的特定严格弱排序准则 进行排序。
4. multiset容器通过key访问单个元素的速度通常比unordered_multiset容器慢,但当使用迭 代器遍历时会得到一个有序序列。
5. multiset底层结构为二叉搜索树(红黑树)
注意:
1. multiset中再底层中存储的是的键值对
2. mtltiset的插入接口中只需要插入即可
3. 与set的区别是,multiset中的元素可以重复,set是中value是唯一的
4. 使用迭代器对multiset中的元素进行遍历,可以得到有序的序列
5. multiset中的元素不能修改
6. 在multiset中找某个元素,时间复杂度为$O(log_2 N)$
7. multiset的作用:可以对元素进行排序
总结:注意与set的区别,insert:返回为迭代器,不是键值对pair<iterator,bool>,仅iterator
3.4 multimap
3.4.1 multimap的介绍
翻译: 1. Multimaps是关联式容器,它按照特定的顺序,存储由key和value映射成的键值对,其中多个键值对之间的key是可以重复的。
2. 在multimap中,通常按照key排序和惟一地标识元素,而映射的value存储与key关联的内 容。key和value的类型可能不同,通过multimap内部的成员类型value_type组合在一起, value_type是组合key和value的键值对: typedef pair value_type;
3. 在内部,multimap中的元素总是通过其内部比较对象,按照指定的特定严格弱排序标准对 key进行排序的。
4. multimap通过key访问单个元素的速度通常比unordered_multimap容器慢,但是使用迭代 器直接遍历multimap中的元素可以得到关于key有序的序列。
5. multimap在底层用二叉搜索树(红黑树)来实现。
注意:multimap和map的唯一不同就是:map中的key是唯一的,而multimap中key是可以重复的
3.4.2 multimap的使用
multimap中的接口可以参考map,功能都是类似的。
注意: 1. multimap中的key是可以重复的。
2. multimap中的元素默认将key按照小于来比较
3. multimap中没有重载operator[]操作(同学们可思考下为什么?)。无法返value.
4. 使用时与map包含的头文件相同:
3.5 在OJ中的使用
692. 前K个高频单词 - 力扣(LeetCode)
349. 两个数组的交集 - 力扣(LeetCode)
相关文章:

STL-map和set
目录 一、关联式容器 二、键值对 三、树形结构的关联式容器 3.1 set 3.1.1 set介绍 3.1.2 set的使用 1. set的模板参数列表 2. set的构造 3. set的迭代器(类型是双向迭代器) 4. set的容量 5.set修改操作 6、operator 7. set的使用举例 3.2 map 3.2.1map介绍 3.2.2map的…...
[蓝桥杯 2020 省 B1] 整除序列
[蓝桥杯 2020 省 B1] 整除序列 题目描述 有一个序列,序列的第一个数是 n n n,后面的每个数是前一个数整除 2 2 2,请输出这个序列中值为正数的项。 输入格式 输入一行包含一个整数 n n n。 输出格式 输出一行,包含多个整数…...

【Android】View 的滑动
View 的滑动是 Android 实现自定义控件的基础,同时在开发中我们也难免会遇到 View 的滑动处理。其实不管是哪种滑动方式,其基本思想都是类似的:当点击事件传到 View 时,系统记下触摸点的坐标,手指移动时系统记下移动后…...

基于ZYNQ的PCIE高速数据采集卡的设计(一)
作为信息处理的第一步,数据采集的作用越来越重要。目前,数据采集已经在航 空、民用、军事、医疗等领域得到广泛应用。随着相关技术的不断发展,信号频率越 来高,带宽越来越大,使得数据采集技术逐渐向高速大数据的方向…...
渗透测试工具 nmap 详解
官网:Nmap: the Network Mapper - Free Security Scanner -p<端口范围>:仅扫描指定的端口 用于扫描指定端口是否开放,在 -p 后输入指定的端口,以英文","进行拼接多个指定端口。 nmap -p 80&…...

Ubuntu下安装Scala
前言 弄了一下终于成功装上了,这里对此进行一下总结 安装虚拟机 VMware虚拟机安装Ubuntu(超详细图文教程)_vmware安装ubuntu-CSDN博客https://blog.csdn.net/qq_43374681/article/details/129248167Download Ubuntu Desktop | Download | …...

无法启动报,To install it, you can run: npm install --save @/components/iFrame/index
运行的过程中后台报错 npm install --save /components/iFrame/index,以为是安装三方依赖错误,经过多次重装node_modules依然没有用。 没办法,只能在项目中搜索 components/iFrame/index这个文件。。突然醒悟。。。 有时候,犯迷…...

深入理解现代JavaScript:从语言特性到应用实践
💂 个人网站:【 海拥】【神级代码资源网站】【办公神器】🤟 基于Web端打造的:👉轻量化工具创作平台💅 想寻找共同学习交流的小伙伴,请点击【全栈技术交流群】 JavaScript作为一门动态、解释性脚本语言&…...

ThreadPoolExecutor 学习
ThreadPoolExecutor 是开发中最常用的线程池,今天来简单学习一下它的用法以及内部构造。 1、线程池存在的意义? 一般在jvm上,用户线程和操作系统内核线程是1:1的关系,也就是说,每次创建、销毁线程的时候&am…...
深入理解计算机操作系统书籍阅读感悟(一)
1.sp:表示为空格,ASCII为32 2.在我们写的每行程序结尾都有一个隐藏的\n(ASCII码值为10) 3.在书上的P2页上说:文本文件是指以ASCII码字符构成的文件,其余都是二进制文件 除了这种理解,更常见的…...

使用query请求数据出现500的报错
我在写项目的时候遇到了一个问题,就是在存商品id的时候我将它使用了JSON.stringify的格式转换了!!!于是便爆出了500这个错误!!! 我将JSON.stringify的格式去除之后,它就正常显示了&…...
PostgreSQL教程(二十一):服务器管理(三)之服务器设置和操作
本章讨论如何设置和运行数据库服务器,以及它与操作系统的交互。 一、PostgreSQL用户账户 和对外部世界可访问的任何服务器守护进程一样,我们也建议在一个独立的用户账户下运行PostgreSQL。这个用户账户应该只拥有被该服务器管理的数据,并且…...
Linux运维_Bash脚本_编译安装GNU-Tools
Linux运维_Bash脚本_编译安装GNU-Tools Bash (Bourne Again Shell) 是一个解释器,负责处理 Unix 系统命令行上的命令。它是由 Brian Fox 编写的免费软件,并于 1989 年发布的免费软件,作为 Sh (Bourne Shell) 的替代品。 您可以在 Linux 和 …...
leetcode 121.买卖股票的最佳时机
声明:以下仅代表个人想法,非官方答案或最优题解! 题目: 给定一个数组 prices ,它的第 i 个元素 prices[i] 表示一支给定股票第 i 天的价格。 你只能选择 某一天 买入这只股票,并选择在 未来的某一个不同的…...

javaWebssh酒店客房管理系统myeclipse开发mysql数据库MVC模式java编程计算机网页设计
一、源码特点 java ssh酒店客房管理系统是一套完善的web设计系统(系统采用ssh框架进行设计开发),对理解JSP java编程开发语言有帮助,系统具有完整的源代码和数据库,系统主要采用B/S模式开发。开发环境为TOMCAT7.0…...

vue3基础教程(2)——创建vue3+vite项目
博主个人微信小程序已经上线:【中二少年工具箱】。欢迎搜索试用 正文开始 专栏简介1. 前言2.node版本检测3.创建vue项目 专栏简介 本系列文章由浅入深,从基础知识到实战开发,非常适合入门同学。 零基础读者也能成功由本系列文章入门&#x…...
部署DNS 实战篇
二、DNS 部署 环境介绍 服务器3台、系统centos 安装软件 yum install -y bind bind-utils bind-chrootbind 主包bind-utils 客户端测试工具(host 、dig 、nslookup)bind-chroot chroot环境 禁锢dns服务器的工作目录caching-nameserver(rhel5提供…...

2023 2024年全国职业院校技能大赛中职组网络建设与运维赛项服务器Linux部分教程解析
欢迎合作 需要资料请私 Rocky 9 包含各种常考服务(包括新题型KVM等)...
Flask g对象和插件
四、Flask进阶 1. Flask插件 I. flask-caching 安装 pip install flask-caching初始化 from flask_cache import Cache cache Cache(config(CACHE_TYPE:"simple" )) cache.init_app(appapp)使用 在视图函数上添加缓存 blue.route("/") cache.cached(tim…...

26、Qt调用.py文件中的函数
一、开发环境 Qt5.12.0 Python3.7.8 64bit 二、使用 新建一个Qt项目,右击项目名称,选择“添加库” 选择“外部库”,点击“下一步” 点击“浏览”,选择Python安装目录下的libs文件夹中的“python37.lib”文件,点击“下…...

LBE-LEX系列工业语音播放器|预警播报器|喇叭蜂鸣器的上位机配置操作说明
LBE-LEX系列工业语音播放器|预警播报器|喇叭蜂鸣器专为工业环境精心打造,完美适配AGV和无人叉车。同时,集成以太网与语音合成技术,为各类高级系统(如MES、调度系统、库位管理、立库等)提供高效便捷的语音交互体验。 L…...
设计模式和设计原则回顾
设计模式和设计原则回顾 23种设计模式是设计原则的完美体现,设计原则设计原则是设计模式的理论基石, 设计模式 在经典的设计模式分类中(如《设计模式:可复用面向对象软件的基础》一书中),总共有23种设计模式,分为三大类: 一、创建型模式(5种) 1. 单例模式(Sing…...

PPT|230页| 制造集团企业供应链端到端的数字化解决方案:从需求到结算的全链路业务闭环构建
制造业采购供应链管理是企业运营的核心环节,供应链协同管理在供应链上下游企业之间建立紧密的合作关系,通过信息共享、资源整合、业务协同等方式,实现供应链的全面管理和优化,提高供应链的效率和透明度,降低供应链的成…...

visual studio 2022更改主题为深色
visual studio 2022更改主题为深色 点击visual studio 上方的 工具-> 选项 在选项窗口中,选择 环境 -> 常规 ,将其中的颜色主题改成深色 点击确定,更改完成...
java调用dll出现unsatisfiedLinkError以及JNA和JNI的区别
UnsatisfiedLinkError 在对接硬件设备中,我们会遇到使用 java 调用 dll文件 的情况,此时大概率出现UnsatisfiedLinkError链接错误,原因可能有如下几种 类名错误包名错误方法名参数错误使用 JNI 协议调用,结果 dll 未实现 JNI 协…...

汽车生产虚拟实训中的技能提升与生产优化
在制造业蓬勃发展的大背景下,虚拟教学实训宛如一颗璀璨的新星,正发挥着不可或缺且日益凸显的关键作用,源源不断地为企业的稳健前行与创新发展注入磅礴强大的动力。就以汽车制造企业这一极具代表性的行业主体为例,汽车生产线上各类…...

《基于Apache Flink的流处理》笔记
思维导图 1-3 章 4-7章 8-11 章 参考资料 源码: https://github.com/streaming-with-flink 博客 https://flink.apache.org/bloghttps://www.ververica.com/blog 聚会及会议 https://flink-forward.orghttps://www.meetup.com/topics/apache-flink https://n…...
根据万维钢·精英日课6的内容,使用AI(2025)可以参考以下方法:
根据万维钢精英日课6的内容,使用AI(2025)可以参考以下方法: 四个洞见 模型已经比人聪明:以ChatGPT o3为代表的AI非常强大,能运用高级理论解释道理、引用最新学术论文,生成对顶尖科学家都有用的…...

佰力博科技与您探讨热释电测量的几种方法
热释电的测量主要涉及热释电系数的测定,这是表征热释电材料性能的重要参数。热释电系数的测量方法主要包括静态法、动态法和积分电荷法。其中,积分电荷法最为常用,其原理是通过测量在电容器上积累的热释电电荷,从而确定热释电系数…...
Java毕业设计:WML信息查询与后端信息发布系统开发
JAVAWML信息查询与后端信息发布系统实现 一、系统概述 本系统基于Java和WML(无线标记语言)技术开发,实现了移动设备上的信息查询与后端信息发布功能。系统采用B/S架构,服务器端使用Java Servlet处理请求,数据库采用MySQL存储信息࿰…...