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

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

文章目录

  • ⭐一、系列式容器和关联式容器
  • 🚀二、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.rhkb.cn/news/445741.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

git删除错误的commit

文章目录 1、git删除错误的commit2、.gitignore配置文件不生效的问题 1、git删除错误的commit git的流程如图&#xff1a; 当某次失误造成commit的版本有问题&#xff0c;需要回退到正常的版本修改后重新add。 首先通过git log查看commit提交记录&#xff0c;可以看到HEAD-…

【在Linux世界中追寻伟大的One Piece】信号捕捉|阻塞信号

目录 1 -> 信号捕捉初识 2 -> 阻塞信号 2.1 -> 信号其他相关常见概念 2.2 -> 在内核中的表示 2.3 -> sigset_t 2.4 -> 信号集操作函数 2.5 -> sigprocmask 2.6 -> sigpending 3 -> 捕捉信号 3.1 -> 内核如何实现信号的捕捉 3.2 ->…

在Spring Boot中具有多个实现的接口正确注入的六种方式

​ 博客主页: 南来_北往 系列专栏&#xff1a;Spring Boot实战 在Spring Boot中&#xff0c;当一个接口具有多个实现时&#xff0c;正确地将这些实现注入到需要使用它们的地方是一个常见的需求。以下是在Spring Boot中实现这一目标的六种方式&#xff1a; 1. 使用Autowir…

Apple A18 和 A18 Pro 的裸晶照揭示出兩款處理器有著不同的設計

向來蘋果在發布使用新晶片的設備後&#xff0c;就會有人為新晶片進行詳細剖析&#xff0c;看看蘋果在新處理器上面又使用了什麼新技術。如今 iPhone 16 系列已經推出&#xff0c; Apple A18 和A18 Pro 兩款處理器自然也成為了研究對象。最近就有機構將 Apple A18 和 A18 Pro 兩…

雷池社区版本SYSlog使用教程

雷池会对恶意攻击进行拦截&#xff0c;但是日志都在雷池机器上显示 如何把日志都同步到相关设备进行统一的管理和分析呢&#xff1f; 如需将雷池攻击日志实时同步到第三方服务器, 可使用雷池的 Syslog 外发 功能 启用 Syslog 外发 进入雷池 系统设置 页面, 配置 Syslog 设置…

Miniconda更改虚拟环境创建路径

Miniconda更改虚拟环境创建路径 文章目录 Miniconda更改虚拟环境创建路径前言步骤一 修改配置文件步骤二 提升路径访问权限步骤三 测试配置修改是否生效 前言 在我使用 conda 命令创建新的虚拟环境时&#xff0c;发现创建好的虚拟环境存放路径是在 ../miniconda3/pkgs/ 路径下…

Python 在Excel中添加数据条

在Excel中添加数据条是一种数据可视化技巧&#xff0c;它通过条形图的形式在单元格内直观展示数值的大小&#xff0c;尤其适合比较同一列或行中各个单元格的数值。这种表示方式可以让大量的数字信息一目了然。本文将介绍如何使用Python在Excel中的指定单元格区域添加数据条。 …

Android:记录一个打包发布版的release包以后闪退的问题

个人感觉其实release闪退的问题挺难排查的&#xff0c;因为release包运行起来as捕获不到相应的应用程序进程&#xff0c;从而不易查看到日志&#xff0c;也是我玩得不溜&#xff0c;大家有不同的方法可以评论区探讨&#xff0c;我也定期回复一些评论一起讨论。以下是我遇到的情…

计算机毕业设计 基于Hadoop的智慧校园数据共享平台的设计与实现 Python毕业设计 Python毕业设计选题 Spark 大数据【附源码+安装调试】

博主介绍&#xff1a;✌从事软件开发10年之余&#xff0c;专注于Java技术领域、Python人工智能及数据挖掘、小程序项目开发和Android项目开发等。CSDN、掘金、华为云、InfoQ、阿里云等平台优质作者✌ &#x1f345;文末获取源码联系&#x1f345; &#x1f447;&#x1f3fb; 精…

出海电商新怎样用海外云手机引流?

随着互联网行业的迅猛发展&#xff0c;出海电商、海外社交媒体营销以及游戏产业等领域对技术工具的需求不断增加。在这种趋势下&#xff0c;海外云手机作为一种新型解决方案&#xff0c;正在受到广泛关注。 特别是在出海电商中&#xff0c;平台如亚马逊、速卖通、eBay等通过结合…

MLCC贴片电容不同材质区别:【及电容工作原理】

贴片电容的材质常规有&#xff1a;NPO&#xff08;COG&#xff09;&#xff0c;X7R&#xff0c;X5R&#xff0c;Y5V 等&#xff0c;主要区别是它们的填充介质不同。在相同的体积下由于填充介质不同所组成的电容器的容量就不同&#xff0c;随之带来的电容器的介质损耗、容量稳定…

GS-LRM: Large Reconstruction Modelfor 3D Gaussian Splatting 论文解读

目录 一、概述 二、相关工作 1、多视图的三维重建 2、前馈重建 三、LRM 1、编码器 2、解码器 3、NeRF渲染 四、GS-LRM 1、输入处理 2、Transformer 3、损失函数 五、实验 六、局限 一、概述 该论文提出了一种利用稀疏输入图像高效预测3D高斯原语的方法&#xff…

鸿蒙--WaterFlow 实现商城首页

目录结构 ├──entry/src/main/ets // 代码区 │ ├──common │ │ ├──constants │ │ │ └──CommonConstants.ets // 公共常量类 │ │ └──utils │ │ └──Logger.ets // 日志打印类 │ ├──entryability │ │ └──EntryAbility.ets // 程序入口…

基于Python Django的在线考试管理系统

&#x1f34a;作者&#xff1a;计算机毕设匠心工作室 &#x1f34a;简介&#xff1a;毕业后就一直专业从事计算机软件程序开发&#xff0c;至今也有8年工作经验。擅长Java、Python、微信小程序、安卓、大数据、PHP、.NET|C#、Golang等。 擅长&#xff1a;按照需求定制化开发项目…

2013年国赛高教杯数学建模C题古塔的变形解题全过程文档及程序

2013年国赛高教杯数学建模 C题 古塔的变形 由于长时间承受自重、气温、风力等各种作用&#xff0c;偶然还要受地震、飓风的影响&#xff0c;古塔会产生各种变形&#xff0c;诸如倾斜、弯曲、扭曲等。为保护古塔&#xff0c;文物部门需适时对古塔进行观测&#xff0c;了解各种变…

AI测试之 TestGPT

如今最火热的技术莫非OpenAI的ChatGPT莫属&#xff0c;AI技术也在很多方面得到广泛应用。今天我们要介绍的TestGPT就是一个软件测试领域中当红的应用。 TestGPT是什么&#xff1f; TestGPT是一家总部位于以色列特拉维夫的初创公司 CodiumAI Ltd.&#xff0c;发布的一款用于测…

Flutter Transform 学习

Transform可以在其子组件绘制时对其应用一些矩阵变换来实现一些特效,允许在渲染子部件之前对它们进行变换。 一、Transform构造函数与属性 class Transform extends SingleChildRenderObjectWidget {/// Creates a widget that transforms its child.const Transform({super.k…

231水果滑块喜+1

有需求可以联系博主 let v Died_in2021

飞机大战ai通过dqn实现

借鉴 飞机大战源码 github 王者荣耀ai训练(试了一下&#xff0c;发现电脑带不动&#xff0c;就改了一点&#xff0c;训练其他游戏) 源码 通过网盘分享的文件&#xff1a;PlaneWar (2).zip [链接]&#xff08;https://pan.baidu.com/s/1N4OorR7b36Zml8MadGmI6g?pwd1234&#xf…

经纬恒润荣获2024中国汽车供应链大会创新成果奖

2024年9月24日-26日&#xff0c;2024中国汽车供应链大会暨第三届中国新能源智能网联汽车生态大会在武汉隆重举办。本届大会以“新挑战、新对策、新机遇——推动中国汽车供应链可持续发展”为主题&#xff0c;集聚政府主管领导、行业专家、汽车及零部件企业精英和主流媒体&#…