C++ STL容器之set使用及复现

c++set

1. 关联式容器

vector、list、deque、forward_list(C++11) 等STL容器,其底层为线性序列的数据结构,里面存储的是元素本身,这样的容器被统称为序列式容器。而 map、set 是一种关联式容器,关联式容器也是用来存储数据的,与序列式容器不同的是,关联式容器里面存储的是 <key, value> 结构的键值对,在数据检索时比序列式容器效率更高。map 和 set 的键是唯一的,但是 mutimap 和 multiset 支持多个同名且有不同映射的键共存。

2. 键值对

用来表示具有一一对应关系的一种结构,该结构中一般只包含两个成员变量 key 和 value, key 代表键值,value 表示与 key 对应的信息。比如:学生的姓名和他的学号是一一对应的,那么就可以通过查找学生的姓名来查找到对应的学号。set 容器是 key 结构。set 不允许存在相同的 key(multiset除外),且 key 不可修改(因为会破坏内部的红黑树结构)。

3.set容器

形参含义:

T:键值对应 value 的类型。
Compare:比较器的类型,缺省情况下按照小于来比较,一般情况下(内置类型元索)该参数不需要传递,如果无法比较时(自定义类型),需要用户自己显式传递比较规则(一般情况下按照函数指针或者仿函数来传递)。
Alloc:通过空间配置器来申请底层空间,不需要用户传递,除非用户不想使用标准库提供的空间配置器。

4.set的成员函数

4.1 map的成员函数介绍

set的构造:

函数声明功能介绍
sets()构造一个空的set

set的迭代器:

函数声明功能介绍
begin()end()begin:首元素的位置;end:下一个元素的位置
cbegin()cend()c指const,cbegin和cend指向的内容不能修改
rbegin()rend()反向迭代器,rbegin从end开始,rend从begin开始,其++和–的方向相反
crbegin()crend()与前一个功能相同,但指向的内容不能修改

set的容量与元素访问:

函数名函数声明功能介绍
emptybool empty() const检测set中的元素是否为空,为空返回ture,不为空返回false
sizesize_type size() const返回set中有效元素的个数

set的修改:

函数名函数声明功能介绍
insertpair<iterator,bool> insert (const value_type& val)在 set 中插入键值对 x,注意 x 是一个键值对,返回值也是键值对;iterator 代表新插入元素的位置,bool 代表插入成功
erasevoid erase (iterator position)
size_type erase (const value_type& val)
void erase (iterator first, iterator last)
删除 position 位置上的元素
删除键值为 x 的元素
删除 [first,last) 区间中的元素
swapvoid swap (set& x)交换两个 set 中的元素
clearvoid clear()删除 set 里所有的元素

set的操作:

函数名函数声明功能介绍
finditerator find (const value_type& val) const搜索set里键等于k的元素,如果找到返回一个映射的迭代器,找不到返回end的迭代器,find函数默认查找中序的第一个相等的值
countsize_type count (const value_type& val) const搜索set里键等于k的元素,找到返回1,找不到返回0
lower_bounditerator lower_bound (const value_type& val) const在set里找>=k的元素,返回符合情况的最小键的迭代器
upper_bounditerator upper_bound (const value_type& val) const在set里找>k的元素,返回符合情况的最小键的迭代器
equal_rangepair<iterator,iterator> equal_range (const value_type& val) const

5. set的特点

STL 里的 map 和 set 用的是同一颗红黑树来实现的。

set:

Map7

注意:Rb_tree 里有一个 key_type 和一个 value_type,但 set 应该是 key 和 key 的映射关系,所以在成员变量里,STL 把 key_type和 value_type 都定义了为 _key

map:

Map8

而在 STL 的 map 里,value_type 则定义了一个 pair ,这样做的目的就是为了复用同一颗红黑树。

所以从set和map的底层来看,它们的实现方法分别是:

set<K.> ⟶ \longrightarrow rb_tree<K, K>

map<K, V> ⟶ \longrightarrow rb_tree<K ,pair<const K, V>>

这种写法实际上是由 stl_tree.h 文件中的 val 模板决定你是 key 的 set,还是 key/value 的map:

Map9

6. set的复现

C++ 的 STL 库通过 map 和 set 复用同一颗红黑树实现代码的复用,这里给出 map 的复现链接C++STL容器之map的使用及复现,set 只需要把 map.h 中 key,value 的格式改成 key,key 即可。

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

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

相关文章

激光工控机在精密制造中的应用与优势

在精密制造中&#xff0c;激光工控机可以用于许多场景例如 激光切割与雕刻&#xff1a;用于金属、塑料、陶瓷等材料的精密切割和雕刻&#xff0c;适用于汽车、航空航天、电子等行业&#xff1b;可实现复杂图案和高精度加工&#xff0c;满足微米级精度要求。 激光焊接&#xf…

第 12 天:行为树(Behavior Tree),让 AI 更智能!

&#x1f3af; 目标&#xff1a; ✅ 理解 Unreal Engine 5 行为树&#xff08;Behavior Tree&#xff09; ✅ 创建行为树&#xff08;BT&#xff09;和黑板&#xff08;Blackboard&#xff09;管理 AI 状态 ✅ 使用任务&#xff08;Task&#xff09;让 AI 巡逻、追踪、攻击玩家…

AI眼力训练营:图像标注让机器变聪明

前言 在人工智能的世界里,图像标注就像给机器装上眼睛,让它不再是“瞎子”,而是能清楚看懂图像中的每个物体。想象一下,当我们人类刚开始学习时,常常要借助老师的帮助,指着一只狗说:“这就是狗。”AI也是一样,需要通过大量的“标注”来学会识别图像中的每个物体,就像…

Android 10.0 framework中增加开启和关闭飞行模式的接口

1.前言 在10.0的系统rom定制开发中,在某些产品定制化开发中,需要能通过接口来控制和开启飞行模式的相关 功能,所以就需要从系统settings和下拉状态栏中来看下相关的源码来实现相关功能 2.framework中增加开启和关闭飞行模式的接口的核心类 packages/services/Car/tests/C…

fun-transformer学习笔记-Task1——Transformer、Seq2Seq、Encoder-Decoder、Attention之间的关系

Transformer、Seq2Seq、Encoder-Decoder、Attention由这四者之间的关系可以从模型架构的发展脉络来理解&#xff1a; Seq2Seq 与 Encoder–Decoder 模型 “Seq2Seq”&#xff08;sequence‐to‐sequence&#xff09;是一类用于将一个变长序列映射为另一个变长序列的任务&#x…

WRF-Hydro:高级水文建模系统详解

1. WRF-Hydro 概述 什么是 WRF-Hydro&#xff1f; WRF-Hydro&#xff08;Weather Research and Forecasting Hydrological modeling system&#xff09;是由美国国家大气研究中心&#xff08;NCAR&#xff09;开发的一个用于耦合气象模型和水文模型的高级建模系统。它旨在提供…

公然上线传销项目,Web3 的底线已经被无限突破

作者&#xff1a;Techub 热点速递 撰文&#xff1a;Yangz&#xff0c;Techub News 今天早些时候&#xff0c;OKX 将上线 PI 的消息在圈内引起轩然大波&#xff0c;对于上线被板上钉钉为传销盘子的「项目」 &#xff0c;Techub News 联系了 OKX 公关&#xff0c;但对方拒绝置评…

python的selenium库模拟输入和点击

使用python打开已经登录的谷歌浏览器&#xff0c;模拟录入文本提交数据。1、执行命令行&#xff0c;系统会打开浏览器&#xff0c;手工登录"C:\Program Files\Google\Chrome\Application\chrome.exe" --remote-debugging-port9223 --user-data-dir"C:\tmp"…

Zabbix告警队列清理教程

文章来源&#xff1a;乐维社区 场景&#xff1a;由于网络故障导致&#xff0c;导致zabbix几百上千台机子告警&#xff0c;邮件失败多次尝试发送&#xff0c;导致堆积了很多告警队列&#xff0c;其他邮件产生了时延。一下是两种解决方法。 方法一&#xff1a; 1、查看alerts目…

vue知识点2

1.methods和mounted的区别 methods是定义方法&#xff0c;不涉及到调用 mounted涉及到操作 所以methods后面是&#xff1a;&#xff0c;mounted后面是&#xff08;&#xff09; 2.介绍一下emit的用法 如果子控件要调用父页面的方法&#xff0c;在父页面的子控件引用处&…

Unity中快速制作2D动画:技巧编

用Unity制作2D动画,除了基础操作外,还有一些更高效的技巧和工具组合,可以大幅提升开发效率,以下是本人经验总结: 1. 分秒必争的Sprite Sheet处理 自动切割Sprite Sheet: 在导入Sprite Sheet时,在Sprite Editor中选择 Slice > Automatic,Unity会自动根据透明区域切割…

windows使用cmake编译工程教学:libcurl库源码编译--qt6使用ftp服务--vcpkg下载的包cmake如何使用

windows使用cmake编译工程教学:libcurl库源码编译–qt6使用ftp服务–vcpkg下载的包cmake如何使用 前言 qt6中取消了对ftp协议的支持,所以如果要想在qt中使用tfp服务,需要接入第三方库,也就是libcurl,libcurl需要在本地进行编译,趁这个机会学习一下cmake的使用,记录一下…

网易易盾接入DeepSeek,数字内容安全“智”理能力全面升级

今年农历新年期间&#xff0c;全球AI领域再度掀起了一波革命性浪潮&#xff0c;国产通用大模型DeepSeek凭借其强大的多场景理解与内容生成能力迅速“出圈”&#xff0c;彻底改写全球人工智能产业的格局。 作为国内领先的数字内容风控服务商&#xff0c;网易易盾一直致力于探索…

护照识别设备-护照信息识别系统-PHP护照信息识别接口

护照是公民出入本国国境和到国外旅行时&#xff0c;由本国发给的一种证明该公民国际和身份的合法证件。护照作为重要的个人身份证明证件之一&#xff0c;对于出入境、酒店、旅游业等需要对护照进行信息提取与真伪查验的场景来说至关重要。 人工智能时代&#xff0c;基于文字识…

使用 React 16+Webpack 和 pdfjs-dist 或 react-pdf 实现 PDF 文件显示、定位和高亮

写在前面 在本文中&#xff0c;我们将探讨如何使用 React 16Webpack 和 pdfjs-dist 或 react-pdf 库来实现 PDF 文件的显示、定位和高亮功能。这些库提供了强大的工具和 API&#xff0c;使得在 Web 应用中处理 PDF 文件变得更加容易。 项目设置 首先&#xff0c;我们需要创建…

42页精品PPT | 数字政府智慧政务大数据平台建设方案

这份《数字政府智慧政务大数据平台建设方案》PPT详细阐述了数字政府智慧政务大数据平台的建设背景、目标、架构以及实施策略。方案围绕解决当前政务服务中的痛点&#xff0c;如“互联网政务服务”推进中的数据共享难题、数据安全风险以及部门间业务流程整合等问题展开。 通过构…

使用 Go 语言调用 SiliconFlow 语音生成 API 的脚本,用于将文本转换为 MP3 格式的语音文件。

使用 Go 语言调用 SiliconFlow 语音生成 API 的脚本&#xff0c;用于将文本转换为 MP3 格式的语音文件。 代码结构 包和依赖 package mainimport ("fmt""io""os""path/filepath""github.com/sashabaranov/go-openai" )使…

CSS 小技巧 —— CSS 实现 Tooltip 功能-鼠标 hover 之后出现弹层

CSS 小技巧 —— CSS 实现 Tooltip 功能-鼠标 hover 之后出现弹层 1. 两个元素实现 <!DOCTYPE html> <html lang"zh-CN"> <head><meta charset"UTF-8"><title>纯 CSS 实现 Tooltip 功能-鼠标 hover 之后出现弹层</titl…

网络工程师 (34)生成树协议

前言 生成树协议&#xff08;Spanning Tree Protocol&#xff0c;STP&#xff09;是一种工作在OSI网络模型中第二层&#xff08;数据链路层&#xff09;的通信协议&#xff0c;其基本应用是防止交换机冗余链路产生的环路&#xff0c;确保以太网中无环路的逻辑拓扑结构&#xff…

基于CanMV IDE 开发软件对K210图像识别模块的开发

简介 CanMV IDE 是一款专为 K210 芯片设计的图形识别 Python 软件&#xff0c;它提供了强大的功能&#xff0c;帮助开发者轻松实现基于 K210 芯片的图形识别应用。无论你是初学者还是经验丰富的开发者&#xff0c;CanMV IDE 都能为你提供便捷的开发环境和丰富的资源。 硬件资…