【C++】map、set基本用法

news2025/1/16 3:43:05

欢迎来到我的Blog,点击关注哦💕

前言:

C++的STL已经学习很大一部分了,接下来介绍的是map set是c++的是两种关联容器。

简单介绍

map set

  • 两者都使用红黑树作为底层数据结构来存储元素。
  • map是一种键值对容器,其中每个键都是唯一的,并且与一个值相关联。
  • set则是一个元素集合,其中的每个元素也是唯一的,但它不存储与元素相关联的值。

set(K模型)

set使用介绍

set是标准模板库(STL)中的一种关联容器,它存储的元素是唯一的,并且按照特定的顺序(默认是升序)自动排序。

set的构造

函数声明功能介绍
set (const Compare& comp = Compare(), const Allocator& = Allocator() );构造空的set
set (InputIterator first, InputIterator last, const Compare& comp = Compare(), const Allocator& = Allocator() );用[first, last)区 间中的元素构造
set set ( const set& x);set的拷贝构造

set的迭代器

函数声明功能介绍
iterator begin()返回set中起始位置元素的迭代器
iterator end()返回set中最后一个元素后面的迭代器
const_iterator cbegin() const返回set中起始位置元素的const迭代器
const_iterator cend() const返回set中最后一个元素后面的const迭代器
reverse_iterator rbegin()返回set第一个元素的反向迭代器,即end
reverse_iterator rend()返回set最后一个元素下一个位置的反向迭代器, 即rbegin
const_reverse_iterator crbegin()const返回set第一个元素的反向const迭代器,即cend
const_reverse_iterator crend() const返回set最后一个元素下一个位置的反向const迭 代器,即crbegin

set的容量

函数声明功能介绍
bool empty ( ) const检测set是否为空,空返回false,否则返回true
size_type size() const返回set中有效元素的个数

set的修改

函数声明功能介绍
pair insert ( const value_type& x )在set中插入元素x,实际插入的是构成的 键值对,如果插入成功,返回<该元素在set中的 位置,true>,如果插入失败,说明x在set中已经 存在,返回在set中的位置,false>
void erase ( iterator position )删除set中position位置上的元素
size_type erase ( const key_type& x )删除set中值为x的元素,返回删除的元素的个数
void erase ( iterator first, iterator last )删除set中[first, last)区间中的元素
void swap ( set& st );交换set中的元素
void clear ( )将set中的元素清空
iterator find ( const key_type& x ) const返回set中值为x的元素的位置
size_type count ( const key_type& x ) const返回set中值为x的元素的个数

multiset

它允许存储具有相同值的元素,并且这些元素会根据特定的排序准则自动排序。与 set 容器不同,multiset 允许重复的元素值。

  • multiset的操作大致是一样的唯一的额区别就是,multiset允许有重复的元素。
  • 针对set以下接口,大致是留给multiset
函数声明功能介绍
lower_bound返回比这个大于等于这个值的迭代器
upper_bound返回大于这个值的迭代器
equal_rangepair<iterator,iterator> equal_range (const value_type& val) const
返回这个值的区间,满足左闭又开。
  • pair<iterator,iterator>这个返回值是键对值。

map(KV模型)

map是一种关联容器,它存储元素作为键值对(key-value pairs),其中每个键都是唯一的。

map的使用介绍

map的迭代器

函数声明功能介绍
begin()和end()begin:首元素的位置,end最后一个元素的下一个位置
cbegin()和cend()与begin和end意义相同,但cbegin和cend所指向的元素不能修改
rbegin()和rend()反向迭代器,rbegin在end位置,rend在begin位置,其 ++和–操作与begin和end操作移动相反
crbegin()和crend()与rbegin和rend位置相同,操作相同,但crbegin和crend所 指向的元素不能修改

map的容量与元素访问

函数声明功能简介
bool empty ( ) const检测map中的元素是否为空,是返回 true,否则返回false
size_type size() const返回map中有效元素的个数
mapped_type& operator[] (const key_type& k)返回去key对应的value
  • 值得注意的是[]由于map存储的值的键值对.

注意:

  • 在元素访问时,有一个与operator[]类似的操作at()(该函数不常用)函数
  • 都是通过 key找到与key对应的value然后返回其引用
  • 不同的是:当key不存在时,operator[]用默认 value与key构造键值对然后插入,返回该默认value,at()函数直接抛异常。

在这里插入图片描述

代码解析

pair<iterator, bool> ret = insert(key, V());
return ret.first->second;
  • 如果key存在,则返回这等于key的迭代器。
  • 如果key不存在,在则返回新插入节点的迭代器。
pair

std::pair 是 C++ 标准模板库(STL)中的一个模板结构,用于存储一对值。

在这里插入图片描述

在map中是如何赋值:

void TestMap()
{
	map<string, string> m;
	string s1("苹果");
	string s2("apple");
	m.insert(pair<string, string>(s1, s2));
	//C++98pair构造
	m.insert(make_pair("桃子", "peach"));
	//C++11 多参数的构造函数隐式类型转换
	m.insert({ "香蕉","banana" });

	for (auto e : m)
	{
		cout << e.first << ":" << e.second << endl;
	}
}

在这里插入图片描述

map中元素的修改

函数声明功能简介
pair insert ( const value_type& x )在map中插入键值对x,注意x是一个键值对,返回值也是键值对:iterator代表新插入 元素的位置,bool代表释放插入成功
void erase ( iterator position )删除position位置上的元素
size_type erase ( const key_type& x )删除键值为x的元素
void erase ( iterator first, iterator last )删除[first, last)区间中的元素
void swap ( map& mp )交换两个map中的元素
void clear ( )将map中的元素清空
iterator find ( const key_type& x )在map中插入key为x的元素,找到返回该元素的位置的迭代器,否则返回end
const_iterator find ( const key_type& x ) const在map中插入key为x的元素,找到返回该元素的位置的const迭代器,否则返回cend
size_type count ( const key_type& x ) const返回key为x的键值在map中的个数,注意 map中key是唯一的,因此该函数的返回值 要么为0,要么为1,因此也可以用该函数来 检测一个key是否在map中

multimap

multimap是C++标准模板库(STL)中的一种关联容器,它存储键值对,并且允许一个键对应多个值。这与map容器不同,后者对于每个键只存储一个值。

函数声明功能介绍
lower_bound返回比这个大于等于这个值的迭代器
upper_bound返回大于这个值的迭代器
equal_rangepair<iterator,iterator> equal_range (const value_type& val) const 返回这个值的区间,满足左闭又开。

map和set对比

综上所述map和set很相似,很多接口都一样,区别如下

对比维度mapset
存储元素键值对单个值
唯一性键唯一元素唯一
访问方式通过键访问值通过迭代器遍历
修改能力可以通过键修改值元素不可修改
默认排序键升序值升序
底层结构红黑树红黑树


|
| 访问方式 | 通过键访问值 | 通过迭代器遍历
|
| 修改能力 | 可以通过键修改值 | 元素不可修改
|
| 默认排序 | 键升序 | 值升序
|
| 底层结构 | 红黑树 | 红黑树 |

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

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

相关文章

pip package查询网站(性质类似于npmjs.com)

网址&#xff1a;PyPI The Python Package Index python 的依赖包查询网站 就和 node 的 npmjs.com 一样

SD-WAN采用哪种网络技术?如何自建SD-WAN组网?

SD-WAN&#xff08;Software-Defined Wide Area Network&#xff0c;软件定义广域网&#xff09;是一种基于软件的网络架构&#xff0c;它利用软件定义网络&#xff08;SDN&#xff09;的技术来管理广域网&#xff08;WAN&#xff09;的连接和服务。SD-WAN的主要目的是提高网络…

四大LLM模型,预训练和后训练新范式详解

导读 最初&#xff0c;大语言模型LLM的训练过程只关注于预训练&#xff0c;但如今已经扩展到包含预训练和后训练两个阶段。后训练通常包括监督指令微调和对齐&#xff0c;这一方法在ChatGPT发布后广泛流行&#xff01; 翻译自:https://magazine.sebastianraschka.com/p/new-l…

基于距离度量学习的异常检测:一种通过相关距离度量的异常检测方法

异常通常被定义为数据集中与大多数其他项目非常不同的项目。或者说任何与所有其他记录(或几乎所有其他记录)显著不同的记录,并且与其他记录的差异程度超出正常范围,都可以合理地被认为是异常。 例如上图显示的数据集中,我们有四个簇(A、B、C和D)和三个位于这些簇之外的点:P1、P…

领夹麦克风哪个牌子的好,2024年无线领夹麦克风十大品牌推荐

在追求高质量音频的时代&#xff0c;一款性能稳定、音质出色的无线领夹麦克风&#xff0c;不仅能够提升内容创作的品质&#xff0c;也是赠予播客爱好者、视频博主的佳礼。然而&#xff0c;市场上的无线领夹麦克风品种繁多&#xff0c;其中不乏一些厂商为追求低成本&#xff0c;…

微软Phi-3.5系列亮相:性能超越Gemini 1.5和GPT-4o

前沿科技速递&#x1f680; 在人工智能领域&#xff0c;微软从未停止过创新的步伐。尽管与OpenAI的合作为微软带来了显著的成功&#xff0c;但他们显然不满足于此。近日&#xff0c;微软再次在AI领域引发关注&#xff0c;正式发布了三款全新的Phi-3.5系列AI模型。这些模型不仅在…

构建基于LLM的应用程序——使用LLM的搜索和推荐引擎

在上一章中&#xff0c;我们介绍了构建对话应用程序的核心步骤。我们从一个基础的聊天机器人开始&#xff0c;然后逐步添加了更复杂的组件&#xff0c;例如记忆、非参数化知识和外部工具。借助LangChain的预构建组件以及Streamlit的UI渲染&#xff0c;这一切都变得相对简单。尽…

C++ TinyWebServer项目总结(6. 高级 I/O 函数)

文件描述符 文件描述符&#xff08;File Descriptor, FD&#xff09;是操作系统中用于访问文件的一个抽象概念。它是一个非负整数&#xff0c;通常由操作系统分配&#xff0c;用来标识被打开的文件或输入输出资源&#xff08;如管道、网络连接等&#xff09;。文件描述符在操作…

苍穹外卖之员工管理、分类管理

新增员工 新增员工 需求分析和设计 产品原型&#xff1a; 接口设计&#xff1a; 数据库设计&#xff1a; 代码开发 根据新增员工接口设计对应的DTO&#xff1a; 这是实体类属性&#xff0c;但是由于属性差异过大&#xff0c;使用DTO封装数据为&#xff1a; 当前端提交的数据…

java常见面试题汇总

&#x1f30f;个人博客主页&#xff1a;意疏-CSDN博客 希望文章能够给到初学的你一些启发&#xff5e; 如果觉得文章对你有帮助的话&#xff0c;点赞 关注 收藏支持一下笔者吧&#xff5e; 阅读指南&#xff1a; 开篇说明一、封装 继承 多态1.封装2.继承3.多态 二、什么是重载…

非极大值抑制(Non-Maximum Suppression,简称 NMS)

本文为专栏《Python三维点云实战宝典》系列文章&#xff0c;专栏介绍地址“【python三维深度学习】python三维点云从基础到深度学习_python3d点云从基础到深度学习-CSDN博客”。配套书籍《人工智能点云处理及深度学习算法》提供更加全面和系统的解析。 非极大值抑制&#xff08…

揭开数字化转型的神秘面纱

​在当今快速发展的时代&#xff0c;数字化转型已成为众多企业和组织追求的目标。然而&#xff0c;对于许多人来说&#xff0c;数字化转型仍然笼罩着一层神秘的面纱。本研究报告旨在揭开数字化转型的神秘面纱&#xff0c;深入探讨其内涵、重要性以及实施策略。 一、数字化转型的…

开始尝试从0写一个项目--后端(四)

借出&#xff0c;归还&#xff0c;管理 学生和管理员登录分离 学生登录到用户界面 管理员到后台 后台和用户分离 添加代码 sems-server/src/main/java/com/ljc/controller/user/UserStudentController.java package com.ljc.controller.user;import com.ljc.constant.Jwt…

【PyCharm】配置“清华镜像”地址(pip源)

文章目录 前言一、清华镜像是什么&#xff1f;二、pip是什么&#xff1f;三、具体步骤1.复制镜像地址2.打开PyCharm&#xff0c;然后点击下图红框的选项3.在弹出的新窗口点击下图红框的选项进行添加4.在URL输入框中粘贴第一步复制的地址&#xff0c;名字可以不更改&#xff0c;…

leetcode371. 两整数之和,位运算

leetcode371. 两整数之和 给你两个整数 a 和 b &#xff0c;不使用 运算符 和 - ​​​​​​​&#xff0c;计算并返回两整数之和。 示例 1&#xff1a; 输入&#xff1a;a 1, b 2 输出&#xff1a;3 示例 2&#xff1a; 输入&#xff1a;a 2, b 3 输出&#xff1a;5 …

【Axure高保真原型】中继器表格——标签使用情况案例

今天和大家分享中继器表格——标签使用情况案例的原型模板&#xff0c;效果包括&#xff1a; 模糊搜索——输入标签编号或者标签名称&#xff0c;可以快速查找对应的数据 排序——点击排序按钮&#xff0c;可以按升序或降序排列 分页——点击上拉列表&#xff0c;可以选择表格…

gpu压力测试工具----gpu_burn的使用

背景&#xff1a; 我们平时想做gpu的压力测试&#xff0c;需要一个简单的可以一键执行的工具来测试&#xff0c;主要要来打满gpu的使用率和显存&#xff0c;这里以8卡4090机器为测试机&#xff0c;驱动版本550.54.14&#xff0c;cuda版本12.3。 开源方案&#xff1a; gpu-burn一…

oauth2.0学习

一、授权码模式 时序图 1、用户访问第三方服务&#xff0c;如果用到需要授权服务提供授权的资源&#xff0c;第三方服务生成获取授权码请求&#xff08;附带回调地址和用户在授权服务的确认身份的信息&#xff09;并页面发起请求 2、第三方授权服务根据请求生成对应的登录地址…

c++ 谷歌的招聘 题解

题目描述 2004 年 7 月,谷歌在硅谷的 101 号公路边竖立了一块巨大的广告牌(如下图)用于招聘 内容超级简单,就是一个以 .com 结尾的网址,而前面的网址是一个 1010 位素数,这个素数是自然常数 e 中最早出现的 10 位连续数字 能找出这个素数的人,就可以通过访问谷歌的这个网站进…

MySQL 亿级数据平滑迁移实战

作者&#xff1a;来自 vivo 互联网服务器团队- Li Gang 本文介绍了一次 MySQL 数据迁移的流程&#xff0c;通过方案选型、业务改造、双写迁移最终实现了亿级数据的迁移。 一、背景 预约业务是 vivo 游戏中心的重要业务之一。由于历史原因&#xff0c;预约业务数据表与其他业务…