【C++】map和set的介绍以及用法

news2024/11/22 21:13:14

在这里插入图片描述
个人主页
在这里插入图片描述

文章目录

  • ⭐一、系列式容器和关联式容器
  • 🚀二、set的使用
    • 1. set类的介绍
    • 2. set的构造
    • 3. set的迭代器
    • 4. set的常用函数
  • 🎡三、multiset
  • 🎄四、map类的使用
    • 1. map类的介绍
    • 2. map的构造
    • 3. map的迭代器
    • 4. map的operator[]
    • 5. map的常用函数
  • 🏠五、multimap
  • 🚆六、总结

⭐一、系列式容器和关联式容器

在之前学习过程中,我们也接触了STL中的部分容器,如:vector、string、list、deque等,这些都属于序列式容器,因为其底层是线性结构,里面存储的为数据本身。

关联式容器也是用来存储数据的,但不同的是,关联式容器的底层通常是非线性结构的,也就意味着两个位置具有紧密的关联关系,如果进行交换,它们的存储结构就被破坏了。

🚀二、set的使用

1. set类的介绍

我们来看看以下几个有关于set的要点:
1.set是用来存储唯一元素的容器,且按照一定的顺序进行排列。
2.set中不允许出现重复的元素,其本质是负责排序+去重。
3.set在底层是用红黑树来实现的。
4.set的比较默认按照小于进行。
5.set的正向迭代器遍历为升序序列,反向迭代器为降序序列。
6.在set类中的其内容可以进行删除,但不支持修改
7.set中查找某个元素的时间复杂度为logN。

2. set的构造

在set容器中,可以使用多种方式进行构造,以下是常见的构造方式:

1.默认构造:

set<int>  s;

2.迭代器构造:

vector<int> ret = {1, 2, 3, 4, 5};
set<int> s(ret.begin(), ret.end()); 

3.初始化列表构造:

set<int> s = {1,2,3,4};

4.拷贝构造:

set<int> s1 = {1,2,3,4};
set<int> s2(s1);

3. set的迭代器

set容器提供了两种迭代器:一个是正向迭代器,还有一个为反向迭代器。

正向迭代器:
• begin() : 返回指向set容器中的第一个元素。
• end() : 返回指向set容器中的最后一个元素之后的位置。
在这里插入图片描述
反向迭代器:
• rbegin() : 返回指向set容器中的最后一个元素。
• rend() : 返回指向set容器中的第一个元素之前的位置。
在这里插入图片描述

4. set的常用函数

set容器中还提供了一些函数负责元素插入、查找、删除等操作的函数,下面是有关set常用的一些函数:

1.插入元素
在这里插入图片描述

根据文档内容我们可以知道插入元素有三种方式可以进行插入:
• 直接插入一个值val
• 在某一位置插入元素val
• 插入在一个迭代器区间中

注:由于set容器中元素具有唯一性,因此当插入重复元素时,只会插入一个。

2.删除元素
在这里插入图片描述

根据文档内容我们可以知道删除元素有一样也是有三种方式可以进行删除:
• 删除指定迭代器指向位置的元素
• 删除set容器中与val相等的值
• 删除区间[first,last)内的元素。

3.查找元素
在这里插入图片描述
在set容器中查找与val相等的第一个元素,如果找到则返回改元素对应的迭代器区间,否则则返回end的迭代器。

在这里插入图片描述

🎡三、multiset

multiset和set本质上没有太大的区别,主要区别就在于multiset支持值冗余,也就意味着元素是可以重复的。

此外,当在查找冗余数据时,multiset返回的是中序遍历中第一次出现的元素
在这里插入图片描述

🎄四、map类的使用

1. map类的介绍

map是C++中STL的一个关联式容器,它是以键值对来存储数据的,假设我们定义第一个称为关键字key,第二个称为关键字的值value,也就意味着每个关键字只能在map中出现一次。

map的底层存储数据的结构是用红黑树来实现的,也就说明在map内部中所有的数据都是有序的。

2. map的构造

在这里插入图片描述
根据文档内容我们知道map的构造有着三种方式,分别是:

1.无参默认构造

map<int,string> m;

2.迭代器构造

vector<pair<int, string>> ret = {{1, "one"}, {2, "second"}, {3, "third"}};
map<int, string> m(ret.begin(), ret.end());

3.拷贝构造

map<int, string> ret = {{1, "one"}, {2, "second"}, {3, "third"}};
map<int, string> copymap(ret);

3. map的迭代器

map容器提供的迭代器也是跟set一样有正向迭代器和反向迭代器,具体细节就不细讲了,可以看看set的。

map迭代器的使用示例:

正向迭代器:
在这里插入图片描述

反向迭代器:
在这里插入图片描述

4. map的operator[]

在这里插入图片描述
根据文档内容我们可以知道,当key存在时,我们就可以返回key所映射的value值的引用。
在这里插入图片描述

5. map的常用函数

map容器中也提供了一些函数负责元素插入、查找、删除等操作的函数,下面是有关map常用的一些函数:

1.插入元素
在这里插入图片描述
根据文档内容我们发现和set的插入很相似:

• 直接插入一个值val.
• 在某一位置插入元素val.
• 插入在一个迭代器[first,end)区间中.

2.删除元素

在这里插入图片描述

根据文档内容我们可以发现和set容器的删除相似:
• 删除指定迭代器指向位置的元素
• 删除map容器中与val相等的值
• 删除区间[first,last)内的元素。

3.查找元素
在这里插入图片描述
根据文档内容我们发现与set容器的查找相似,这我们就不过多赘述了。

在这里插入图片描述

🏠五、multimap

multimap与map类似,也是键值对的容器,不同之处在于它允许插入重复的键。
在这里插入图片描述

🚆六、总结

今天的分享就到这里啦,希望能帮助大家跟进一步了解set和map的有关知识以及内容。感谢大家的阅读!

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

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

相关文章

Go语言中的控制结构(四)

Go语言中的控制结构详解 控制结构是编程语言中控制代码执行流程的核心部分&#xff0c;Go语言通过if、for、switch等常见的控制结构&#xff0c;以及独有的defer、panic、recover机制&#xff0c;提供了强大且简洁的控制流管理。本文将详细讲解Go语言中的控制结构&#xff0c;包…

第十四章 RabbitMQ延迟消息之延迟队列

目录 一、引言 二、死信队列 三、核心代码实现 四、运行效果 五、总结 一、引言 什么是延迟消息&#xff1f; 发送者发送消息时指定一个时间&#xff0c;消费者不会立刻收到消息&#xff0c;而是在指定时间后收到消息。 什么是延迟任务&#xff1f; 设置在一定时间之后才…

InfluxDB持久层封装

InfluxDB持久层封装 了解如何使用spring-boot来操作InfluxDB数据库&#xff0c;首先我们来看下整个的系统结构图例&#xff1a; 对比下mybatis中的执行流程&#xff1a; 1_自动装配 首先&#xff0c;我们来看下第一步自动装配&#xff1a;依赖spring-boot自动装配出InfluxDB对…

第十五届蓝桥杯C/C++学B组(解)

1.握手问题 解题思路一 数学方法 50个人互相握手 &#xff08;491&#xff09;*49/2 &#xff0c;减去7个人没有互相握手&#xff08;61&#xff09;*6/2 答案&#xff1a;1024 解题思路二 package 十五届;public class Min {public static void main(String[] args) {i…

实时从TDengine数据库采集数据到Kafka Topic

实时从TDengine数据库采集数据到Kafka Topic 一、认识TDengine二、TDengine Kafka Connector三、什么是 Kafka Connect&#xff1f;四、前置条件五、安装 TDengine Connector 插件六、启动 Kafka七、验证 kafka Connect 是否启动成功八、TDengine Source Connector 的使用九、添…

【更新】A股上市公司企业网络安全治理数据集(2007-2023年)

一、测算方式&#xff1a;参考C刊《金融评论》王辉&#xff08;2024&#xff09;老师的做法&#xff0c;安全治理种子词的选取主要依托于《中华人民共和国网络安全法》、《中华人民共和国数据安全法》、《关键信息基础设施安全保护条例》等法律法规文件与《网络安全审查办法》、…

蓝桥杯刷题--幸运数字

幸运数字 题目: 解析: 我们由题目可以知道,某个进制的哈沙德数就是该数和各个位的和取整为0.然后一个幸运数字就是满足所有进制的哈沙德数之和.然后具体就是分为以下几个步骤 1. 我们先写一个方法,里面主要是用来判断,这个数在该进制下是否是哈沙德数 2. 我们在main方法里面调用…

量化之一:均值回归策略

文章目录 均值回归策略理论基础数学公式 关键指标简单移动平均线&#xff08;SMA&#xff09;标准差Z-Score 交易信号实际应用优缺点分析优点缺点 结论 实践backtrader参数&#xff1a;正常情况&#xff1a;异常情况&#xff1a; 均值回归策略 均值回归&#xff08;Mean Rever…

华为公有云实战

1.申请一台ECS云主机&#xff0c;并且可以提供web服务 1.1访问云主机-华为特有技术novnc&#xff0c;KVM中提到vnc技术&#xff0c;novnc是不用安装vnc客户端用浏览器html语言实现。 1.2cloudshell 1.3小工具 ssh 弹性ip 1.4.安装httpd服务 建立索引文件 浏览器上输入弹性ip可…

网络资源模板--Android Studio 实现简易记事本App

目录 一、项目演示 二、项目测试环境 三、项目详情 四、完整的项目源码 一、项目演示 网络资源模板--基于Android studio 实现的简易记事本App 二、项目测试环境 三、项目详情 首页 创建一个空的笔记本列表 mNotebookList。使用该列表和指定的布局资源 item_notebook 创建…

前端开发笔记--html 黑马程序员1

文章目录 前端开发工具--VsCode前端开发基础语法VsCode优秀插件Chinese --中文插件Auto Rename Tag --自动重命名插件open in browserOpen in Default BrowserOpen in Other Browser Live Server -- 实时预览 前端开发工具–VsCode 轻量级与快速启动 快速加载&#xff1a;VSCo…

WordPress添加meta标签做seo优化

一、使用function.php文件添加钩子函数添加 方法1、使用is_page()判断不同页面的page_id进行辨别添加不同页面keyword和description &#xff08;1&#xff09;通过页面前台源码查看对应页面的id &#xff08;2&#xff09;或者通过wordpress后台&#xff0c;点击页面列表&…

云计算ftp 服务器实验

创建VLAN 10 划分端口 创建VLAN 10 的地址 10.1.1.1 服务器的地址是 10.1.1.2 这是服务上的配置 服务器上选择ftp 启动 &#xff0c;文件目录选择一下 在 交换机上 ftp 10.1.1.2 服务器的地址 把刚才创建的shenyq txt 文件下载下到本地交换机 我们能看到交换…

有关安科瑞Acrel-1000DP分布式光伏监控系统在某公司分布式光伏发电项目中的应用探讨-安科瑞 蒋静

摘要&#xff1a;分布式光伏作为可再生能源的一种重要形式&#xff0c;能够根据不同场地的实际情况进行定制&#xff0c;尽可能地利用可用空间&#xff0c;减少对传统化石燃料的依赖&#xff0c;也能降低温室气体排放、改善环境质量。在政策支持和市场需求的双重推动下&#xf…

电脑查不到IP地址是什么原因?怎么解决

在日常使用电脑的过程中&#xff0c;有时会遇到无法查询到电脑IP地址的情况&#xff0c;这可能会影响到网络的正常使用。本文将探讨电脑查不到IP地址的可能原因&#xff0c;并提供相应的解决方案。 一、原因分析 ‌网络连接问题‌&#xff1a;首先&#xff0c;网络连接不稳定或…

MySQL(B站CodeWithMosh)——2024.10.11(14)

ZZZZZZ目的ZZZZZZ代码ZZZZZZ重点ZZZZZZ操作&#xff08;非代码&#xff0c;需要自己手动&#xff09; 8- CASE运算符The CASE Operator_哔哩哔哩_bilibilihttps://www.bilibili.com/video/BV1UE41147KC?p62&vd_sourceeaeec77dfceb13d96cce76cc299fdd08 在sql_store中&am…

智能网联汽车安全隐患,如何化解?

0. 智能网联汽车安全问题如何才能解决&#xff1f;1. TARA 威胁分析与风险评估平台2. CSTP 智能网联汽车网络安全测试平台3. 智能网联汽车安全解决方案4. 车联网测试认证与培训解决方案5. 车联网网络安全实验室建设方案 0. 智能网联汽车安全问题如何才能解决&#xff1f; 智能…

FFmpeg的简单使用【Windows】--- 简单的视频混合拼接

实现功能 点击【选择文件】按钮在弹出的对话框中选择多个视频&#xff0c;这些视频就是一会将要混剪的视频素材&#xff0c;点击【开始处理】按钮之后就会开始对视频进行处理&#xff0c;处理完毕之后会将处理后的文件路径返回&#xff0c;并在页面展示处理后的视频。 视频所…

【数据结构】排序算法系列——桶排序(附源码+图解)

桶排序 算法思想 桶排序&#xff08;BucketSort)&#xff0c;也被叫做箱排序&#xff0c;它将整个数据组分为n个相同大小的子区间&#xff0c;这类子区间或称为桶。输入数据是均匀、独立分布的&#xff0c;所以一般不会出现一个桶中装有过多数据的情况。作为一种排序算法&…

160页PPT | 埃森哲-制造业变革转型八大领域:痛点剖析与改进策略

PT下载链接见文末~ 引言&#xff1a;制造业数字化转型规划 制造业正处于数字化转型的关键时期&#xff0c;旨在通过技术革新和流程优化&#xff0c;灵活应对市场波动&#xff0c;强化竞争优势&#xff0c;并紧跟技术进步的步伐。此规划围绕三大核心要素展开&#xff1a; 1、…