Map+Set

news2025/1/4 17:35:28

    

        我们前面接触过的string、vector、list这些都算序列式容器,它们都有一定的关联性,即使随便换位置也无伤大雅,因为是它们靠位置顺序来保存的。但是今天的MapSet就不是了,它们算关联式容器,两个位置之间有紧密的联系,如果随意交换一下,那它们的结构就被破坏了,因为它们是靠关键字来保存和访问的。

Set

它就是我们之前模拟的Key的使用场景,但是又分为两种,一种就是我们之前模拟实现的,另一种则是Multiset,它是允许重复数据的

这里的T就是我们的Key,而为了防止出现不支持比较的情况,它还给了我们一个仿函数的参数,当然正常我们是用不到的。因为它的底层是红黑树,所以它的效率是logn,迭代器走的是中序,所以它也是有序的。

同时我们可以发现它的迭代器是双向迭代器,所以之后需要注意它只支持++ -- 。

Set的特性之前提到过,因为结构原因不支持改,所以它的核心操作其实就三个,增删查。

这里就可以看出来,它并不是单纯的排序,还带个去重的效果,又因为它贴心的想到了你不喜欢它的排序,所以提供了一个仿函数给你。

它更贴心的为你准备了一次就初始化完。

除了上面的删法还能指定删

需要注意的是这里的返回值是删除的数据个数,所以即使删除的是0也没关系。

不过需要注意的是这里删除完,不论是替代的删还是直接删除节点,编译器都是认为失效的,因为它已经不是原本的它了。

查就很简单了,没那么多弯弯绕绕。不过有另一种比较特别的找法。

count本身是计数的,但是如果说这个数本身就不存在,那么就返回0。

以此来实现找的功能。

同时补充一点,Set为了实现迭代器区间的操作,给了两个成员

lower_bound和upper_bound

这两个就是取出一个区间,并且在这个区间内进行操作。

它们并不要求你给非常准确的区间,只要提供大概就好,lower取大于等于,up取大于。

Multiset

首先Multiset和set没有多大的区别,只是Multiset允许插入重复值,而Multiset遇到第一个要找的值时并不会直接返回,它是走中序,返回的是中序的第一个返回值。

而count在set有就是1没有就是0,到了Multisett就是返回个数和0了

而删除则是删除一个区间。

这样未免有点麻烦

这样多方便

Map

比之前的key之外多了一个key_value ,也就是说它按照key来排,但是多了一个记录可变值的key_value。除了这一点其他的其实都差不多。

那么多了一个key_value,它就支持改的操作了。

不过在此之前,我们需要先了解,它还多了一个pair的模板类型,它有两个参数也就是我们的key和key_value,它支持更改的也是key_value。

它的遍历也应为pair的结构有所变化

first就是key,是不能更改的,而second就是key_value,这个才是能改的。也因为编译器不能一下返回两个数据,所以它用pair包装了一下,让我们可以用->访问到数据。

以及更方便的初始化

到这Map其实就差不多了,除了pair这个结构上的区别,功能实现起来都差不多。

需要注意的点就是它的排序只受到first的影响,如果不是multimap版本,那么两个一样的first但是second不一样,它只会插入第一个,不会受到second的影响。

另一个需要注意的就是这里的operator[],这里的方括号是取得first,但是返回的是second。

而它厉害之处也在于这个pair结构。

这里的[]除了大伙能猜出来的查找修改,还带有插入功能,

不看别的,就这个insert就证明我所言非虚,至少带个插入效果。我们细细的扒一下insert.

不得了,人家的返回值也是个pair,不过这里的pair存的是迭代器和bool类型。

我们可以浅显的理解为iterator是一个迭代器,这个迭代器要么指向新插入的元素,要么就是已有元素的节点,而second的bool存的则是如果成功插入就是true否则就是false,所以咱们想知道到底插入成功没有是看第二个值,所以它在插入的过程中还兼顾到了查找的功能,而这个迭代器里存的是pair类型(不是这里的迭代器pair,而是前面提到过得那种string string类型的pair),所以我们可以通过迭代器的pair修改数据,又达成了改的操作。

不过因为它没有就插入有就返回位置的作用,我们除非特别确定某个值在里面,不然我们是不该使用它来找的,会存在相当一部分的风险。

我复制下来的,大伙将就着看,这里就是[]的实现,可以看到它用迭代器取到了pair,然后用bool记录是新插入还是已有的值,然后再通过iterator取到second返回,返回值是引用,所以它可以被修改,是不是一个很妙的结构。

这里可以看到咱们的cow牛变成了cow羊,并且咱还插入了两个新成员。所以结合以上的特性,这玩意咱还是要谨慎的使用它,因为它无论如何都会 “插入” 的效果确实杀敌一千自损八百。

Multimap

这玩意咱上面见识过了,就是允许重复的first嘛,但是map的插入咱也领教过了,加了这么个特性就是意味着一定能插入成功了,除非没内存了。

而它的删除也是一直删到first不一样位置,也就是类似于区间删。

二叉搜索树需要注意的就是这些,之后的AVL才是重头,这里仅仅只是需要了解它的底层和系统提供的版本的注意点而已。

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

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

相关文章

Linux-df命令使用方法

Linux-df(disk filesystem)命令 df 命令是 Unix 和 Linux 系统中用于报告文件系统磁盘空间使用情况的工具。 df [OPTION]... [FILE]...OPTION 常用选项(博主一般df -h用的较多,可读性较好) -h:以人类可读的…

Uniapp 微信小程序 最新 获取用户头像 和 昵称 方法 有效可用

文章目录 前言代码实现运行效果技术分析 前言 同事有个需求 授权获取用户头像 和 昵称 。之前做过线上小程序发版上线流程 就实现了下 最新的方法和 api 有些变化 记录下 代码实现 先直接上代码 <template><view class"container"><buttonclass&qu…

如何部署北斗定位应用,基于国产自主架构LS2K1000LA-i处理器平台

北斗卫星导航系统(以下简称北斗系统)是着眼于国内经济社会发展需要,自主建设、独立运行的卫星导航系统。经过多年发展,北斗系统已成为面向全球用户提供全天候、全天时、高精度定位、导航与授时服务的重要新型基础设施。 图 1 北斗定位系统的应用优势 强可控:北斗系统是国…

Ollama本地部署大模型及应用

文章目录 前言一、下载安装1.Mac2.Windows3.linux4.docker5.修改配置&#xff08;可选&#xff09;1.linux系统2.window 系统3.mac系统 二、Ollama使用1.命令2.模型下载3.自定义模型4.API 服务 三、Open WebUI 使用四、Dify使用 前言 Ollama 是一个专注于本地部署大型语言模型…

第四届摩纳哥智能化可持续发展游艇码头交流会

第四届摩纳哥智能化可持续发展游艇码头交流会 游艇生态和经济转型 2024年9月23日&#xff0c;第四届摩纳哥智能化可持续发展游艇码头交流会于摩纳哥游艇俱乐部顺利落幕。该交流会由摩纳哥游艇码头顾问公司&#xff08;M3&#xff09;主办&#xff0c;吸引了全球250名游艇行业领…

数据集-目标检测系列-口罩检测数据集 mask>> DataBall

数据集-目标检测系列-口罩检测数据集 mask>> DataBall 数据集-目标检测系列-口罩检测数据集 mask 数据量&#xff1a;1W DataBall 助力快速掌握数据集的信息和使用方式&#xff0c;享有百种数据集&#xff0c;持续增加中。 数据项目地址&#xff1a; gitcode: https…

JAVA笔记 | 实际上用到的策略模式(可直接套用)

自己开发中用到了策略模式&#xff0c;这样写不一定是最好的&#xff0c;但是满足了业务场景跟使用要求&#xff0c;做个笔记&#xff0c;下次有用到可以快速复习跟套用 假设使用场景&#xff1a;有几只宠物&#xff0c;猫跟狗等&#xff0c;要求他们做各种动作&#xff0c;比如…

无人机之物流货运篇

一、无人机货运的崛起 随着电商、快递行业的蓬勃发展&#xff0c;传统的地面物流已经难以满足日益增长的快递量和对速度的追求。而无人机货运凭借其高效、快捷、灵活的特点&#xff0c;逐渐成为了物流行业的新宠。无人机可以在城市上空快速穿梭&#xff0c;不受地面交通拥堵的限…

语言模型发展史

四个阶段 第一阶段&#xff1a;基于规则和统计的语言模型 由人工设计特征并使用统计方法对固定长度的文本窗口序列进行建模分析&#xff0c;这种建模方式也被称为N-gram语言模型。 优点&#xff1a; 1&#xff09;采用极大似然估计, 参数易训练 2&#xff09;完全包含了前n-…

Arthas vmtool(从 jvm 里查询对象,执行 forceGc)

文章目录 二、命令列表2.1 jvm相关命令2.1.15 vmtool&#xff08;从 jvm 里查询对象&#xff0c;执行 forceGc&#xff09;举例1&#xff1a;获取对象 二、命令列表 2.1 jvm相关命令 2.1.15 vmtool&#xff08;从 jvm 里查询对象&#xff0c;执行 forceGc&#xff09; vmtoo…

nodejs 014: React.FC 与 Evergreen(常青树) React UI 框架的的Dialog组件

React.FC React.FC是React中用于定义函数组件“Function Component”的类型。它代表&#xff0c;可以帮助你在TypeScript中提供类型检查和自动补全。使用React.FC时&#xff0c;可以明确指定组件的props类型&#xff0c;并且它会自动推导children属性。下面是一个使用 React.F…

微服务-- Gateway服务网关

Spring Cloud Gateway 是 Spring Cloud 的一个全新项目&#xff0c;该项目是基于 Spring 5.0&#xff0c;Spring Boot 2.0 和 Project Reactor 等响应式编程和事件流技术开发的网关&#xff0c;它旨在为微服务架构提供一种简单有效的统一的 API 路由管理方式。 为什么需要网关…

从0开始linux(5)——vim

欢迎来到博主的专栏&#xff1a;从0开始linux 博主ID&#xff1a;代码小豪 文章目录 vim的多种模式底行模式命令命令模式视块模式&#xff08;visual block&#xff09; vim的配置 vim是linux系统的文本编辑器。就像windows的记事本一样。 使用vim指令可以使用vim打开一个文本文…

MacOS多桌面调度快捷键

单桌面调度快捷键 可能是我用着妙控鼠标用着不习惯&#xff0c;所以追求快捷键操作&#xff0c;看起来也比较酷。而且在Windows上&#xff0c;我基本不使用多桌面&#xff0c;但是看着同事用Mac的多桌面用的飞起&#xff0c;炫酷程度不亚于win7的Windows键Tab。在不使用多桌面的…

小川科技携手阿里云数据库MongoDB:数据赋能企业构建年轻娱乐生态

随着信息技术的飞速发展&#xff0c;企业在处理海量数据时所面临的挑战日益严峻。特别是在年轻娱乐领域&#xff0c;用户行为的多样性和数据量的激增对数据存储与分析技术提出了更高的要求。在此背景下&#xff0c;小川凭借其前瞻性的技术视野&#xff0c;选择了MongoDB作为其数…

乒乓buffer(国科微笔试填空)_2024年9月26日

乒乓buffer是否提高了并行度&#xff1f;是 流水线式处理&#xff0c;提高并行度 位宽为4&#xff0c;深度为8的sram&#xff1a; 当sel拉高时&#xff0c;a、b模块在wren和rden有效时分别写和读&#xff1b;当sel拉低时&#xff0c;a、b模块在rdenwren有效时分别读和写

远程访问软路由

远程访问软路由主要涉及通过互联网从远程位置访问和控制基于软件的路由器系统。以下是远程访问软路由的一般方法&#xff1a; 一、远程访问软路由的方法 通过Web管理界面访问&#xff1a; 适用于大多数支持Web管理的软路由系统。用户只需在浏览器中输入软路由的公网IP地址或域…

【C语言】手把手带你拿捏指针(完)(指针笔试、面试题解析)

文章目录 一、sizeof和strlen的对⽐1.sizeof2.strlen3.sizeof与strlen对比 二、数组和指针笔试解析1.一维数组2.字符、字符串数组和字符指针代码1代码2代码3代码4代码5代码6 3.二维数组4.总结 三、指针运算笔试题解析代码1代码2代码3代码4代码5代码6 一、sizeof和strlen的对⽐ …

freeRDP OPenssl

libusb需要下载 我使用的是VS2019编译 所以需要include 与vs2019 在cmake里面修改路径 C:/Users/JPM/source/repos/freeRDP/FreeRDP-stable-2.0/libusb-1.0.24/include/libusb-1.0 C:/Users/JPM/source/repos/freeRDP/FreeRDP-stable-2.0/libusb-1.0.24/VS2019/MS64/static/l…

【中级通信工程师】终端与业务(四):通信产品

【零基础3天通关中级通信工程师】 终端与业务(四)&#xff1a;通信产品 本文是中级通信工程师考试《终端与业务》科目第四章《通信产品》的复习资料和真题汇总。终端与业务是通信考试里最简单的科目&#xff0c;有效复习通过率可达90%以上&#xff0c;本文结合了高频考点和近几…