map和set使用讲解

news2025/1/11 17:12:11

map的使用

map的介绍

  • map是C++ STL(标准模板库)中的一个关联容器。

  • 它提供了一种有序的键值对存储方式,其中每个元素都由一个键和一个值组成。

  • map中的元素根据键的值自动进行排序,并且通过键快速访问对应的值。

  • map使用红黑树数据结构来实现内部的存储和排序。

  • 红黑树是一种平衡二叉搜索树,可以保证插入、删除和查找操作的时间复杂度都是对数级别(O(logn))

insert接口的使用

  • 插入单个键值对:

std::map<int, std::string> myMap;
myMap.insert(std::make_pair(1, "apple"));
  • 使用emplace函数插入新的键值对:

std::map<int, std::string> myMap;
myMap.emplace(3, "orange");

emplace函数是C++11引入的新特性,可以在插入时直接构造键值对。 需要注意的是,如果插入的键已经存在于map中,则insert函数不会插入新的键值对,而是返回一个std::pair类型的迭代器,指向已经存在的键值对。

  • 使用迭代器对一组数据进行插入

 string str[10] = { "数据1","数据2","数据3" ,"数据4" ,
  "数据5" ,"数据6" ,"数据7" ,"数据8" ,"数据9" ,"数据10" };
 vector<pair<string, int>> p1 = { {"数据1",1},{"数据2",2}, {"数据3",3}, {"数据4",4} ,{"数据5",5} ,{"数据6",6} ,{"数据7",7} ,{"数据8",8} ,{"数据9",9}, {"数据10",10} };
 mp1.insert(p1.begin(),p1.end());


只需要给定数据容器的迭代器,编译器便会遍历插入

erase

  • map的erase函数用于删除map中指定键对应的元素。它提供了多个重载版本,可以根据不同的需求进行使用。

  • 删除单个键值对:

std::map<int, std::string> myMap;
myMap.insert(std::make_pair(1, "apple"));
myMap.insert(std::make_pair(2, "banana"));
myMap.erase(1);

上述代码将删除键为1的键值对。调用erase函数时,传入要删除的键作为参数。

  • 使用迭代器删除元素:

std::map<int, std::string> myMap;
myMap.insert(std::make_pair(1, "apple"));
myMap.insert(std::make_pair(2, "banana"));
auto it = myMap.find(1);
if (it != myMap.end()) {
    myMap.erase(it);
}

上述代码通过先使用find函数查找到要删除的键对应的迭代器,然后调用erase函数来删除元素。

  • 删除一定范围内的元素:

std::map<int, std::string> myMap;
myMap.insert(std::make_pair(1, "apple"));
myMap.insert(std::make_pair(2, "banana"));
myMap.insert(std::make_pair(3, "orange"));
myMap.erase(myMap.begin(), myMap.find(2));

find接口的使用

  • map的find函数用于在map中查找指定键对应的元素。它返回一个迭代器,指向该键对应的元素,如果键不存在,则返回end迭代器。

std::map<int, std::string> myMap;
myMap.insert(std::make_pair(1, "apple"));
myMap.insert(std::make_pair(2, "banana"));
myMap.insert(std::make_pair(3, "orange"));
auto it = myMap.find(2);
if (it != myMap.end()) {
    std::cout << "Key found! Value is: " << it->second << std::endl;
} else {
    std::cout << "Key not found!" << std::endl;
}
  • 上述代码中,我们创建了一个map,并向其中插入了一些键值对。然后,使用find函数查找键为2的元素。如果找到了该键,打印对应的值;如果未找到,输出"Key not found!"。find函数返回的是一个迭代器,指向找到的元素。如果键不存在于map中,则返回end迭代器,它指向map中最后一个元素之后的位置。

clear接口的使用

  • map的clear函数用于删除map中的所有元素,使其成为空map。使用clear函数不会改变map的容量,只是将其中的键值对全部删除。

std::map<int, std::string> myMap;
myMap.insert(std::make_pair(1, "apple"));
myMap.insert(std::make_pair(2, "banana"));
myMap.insert(std::make_pair(3, "orange"));
myMap.clear();

上述代码中,我们创建了一个map,并向其中插入了一些键值对。然后,调用clear函数将所有元素都删除。

map的应用

  • 当成计数数组使用

  • 快速查找

set的使用

set的介绍

  • STL中的set是一种有序的关联容器

  • 它基于红黑树的数据结构实现。

  • set的特点如下:

  1. 唯一性:set中的元素是唯一的,不允许重复。如果尝试向set中添加已经存在的元素,操作将被忽略。

  2. 有序性:set中的元素按照一定的顺序进行存储,默认情况下是升序排列。可以通过自定义比较函数来改变排序方式。

  3. 快速插入与删除:set对插入和删除操作具有高效性能。红黑树结构可以自动调整以保持平衡,从而保证了常数时间复杂度的插入和删除操作。

  4. 快速查找:set内部使用二叉搜索树(红黑树)实现,使得查找操作具有很高的效率。平均情况下的时间复杂度为O(log n)。

  5. 提供迭代器支持:可以使用迭代器遍历set中的元素,支持正向和反向迭代。

insert接口的介绍

  • 可以使用insert()方法向set中添加元素。如果添加的元素已经存在于set中,则不会有任何变化。

mySet.insert(4);  // 添加元素4到set中

erase和clear接口的介绍

  • 可以使用erase()方法从set中删除指定的元素。如果指定的元素不存在于set中,不会有任何变化。另外,还可以使用clear()方法清空set中的所有元素。

mySet.erase(3);  // 从set中删除元素3
mySet.clear();  // 清空set中的所有元素

find接口的介绍

  • 可以使用find()方法来查找set中的元素。如果找到了指定元素,返回指向该元素的迭代器;否则返回set的end()迭代器。

auto it = mySet.find(2);  // 查找元素2
if (it != mySet.end()) 
{
    // 元素存在
} 
else 
{
    // 元素不存在
}

set的应用

  • 它在去重、成员关系判断和集合运算等方面都有广泛的应用。

  • 要注意,set对于元素的插入和删除操作会导致树结构的调整,因此在某些情况下可能比unordered_set(哈希表实现)慢一些。

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

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

相关文章

【HTML5】 canvas 绘制图形

文章目录 一、基本用法二、用法详见2.0、方法属性2.1、绘制线条2.2、绘制矩形2.3、绘制圆形2.4、绘制文本2.5、填充图像 一、基本用法 canvas 标签&#xff1a;可用于在网页上绘制图形&#xff08;使用 JavaScript 在网页上绘制图像&#xff09;画布是一个矩形区域&#xff0c…

如何搭建企业管理系统Odoo并实现无公网ip远程访问管理界面

文章目录 前言1. 下载安装Odoo&#xff1a;2. 实现公网访问Odoo本地系统&#xff1a;3. 固定域名访问Odoo本地系统 前言 Odoo是全球流行的开源企业管理套件&#xff0c;是一个一站式全功能ERP及电商平台。 开源性质&#xff1a;Odoo是一个开源的ERP软件&#xff0c;这意味着企…

软件设计不是CRUD(10):低耦合模块设计理论——业务抽象:从需求中提取业务维度

接上文《软件设计不是CRUD(9):低耦合模块设计理论——设计落地所面临的挑战》 2、什么是业务抽象 业务抽象是一种将需求落地成模块功能的设计思想,是对业务需求和技术设计进行转换、隔离的一种分析方法。经过业务抽象后的业务模块一般具有较高的业务屈服度,能更大程度满…

Nginx设置域名转发到服务器指定的端口

&#x1f341; 作者&#xff1a;知识浅谈&#xff0c;CSDN签约讲师&#xff0c;CSDN博客专家&#xff0c;华为云云享专家&#xff0c;阿里云专家博主 &#x1f4cc; 擅长领域&#xff1a;全栈工程师、爬虫、ACM算法 &#x1f492; 公众号&#xff1a;知识浅谈 &#x1f525;网站…

git提交文本或者word到git教程,git创建仓库时候自带

简易的命令行入门教程: Git 全局设置: git config --global user.name “XX” git config --global user.email “XXXqq.com” 创建 git 仓库: mkdir test cd test git init touch README.md git add README.md git commit -m “first commit” git remote add origin https:…

一款全面且多功能的安全扫描仪

工具介绍 Trivy&#xff08;发音&#xff09;是一款全面且多功能的安全扫描仪。Trivy 拥有用于查找安全问题的扫描仪&#xff0c;以及可以找到这些问题的目标。 目标&#xff08;Trivy 可以扫描的内容&#xff09;&#xff1a; 容器镜像 文件系统 Git 存储库&#xff08;远…

基础篇_开发web程序(C/S架构,SpringBoot,贷款计算器-WEB版)

文章目录 一. C/S 架构1. C/S 架构2. URL 格式 二. Spring Boot1. 向导生成2. 准备工作1) 修改版本2) 修改maven 设置 3. 导入模块4. hello world5. 处理输入页面接收参数练习 - 加法 三. 贷款计算器 - WEB 版1. 数组定义改写贷款计算器越界遍历默认值 2. 二维数组3. 贷款计算器…

基于ssm的疫情防控管理系统设计与实现论文

摘 要 传统办法管理信息首先需要花费的时间比较多&#xff0c;其次数据出错率比较高&#xff0c;而且对错误的数据进行更改也比较困难&#xff0c;最后&#xff0c;检索数据费事费力。因此&#xff0c;在计算机上安装疫情防控管理系统软件来发挥其高效地信息处理的作用&#x…

感知器学习算法和Adaline规则

一.感知器的发展过程 感知器的发展可以追溯到20世纪50年代。它是一种简单的人工神经网络模型&#xff0c;最早由美国心理学家和计算机科学家弗兰克罗森布拉特&#xff08;Frank Rosenblatt&#xff09;于1957年提出。感知器的设计灵感来源于生物神经元的工作原理&#xff0c;旨…

【Spring】SpringBoot 统一功能处理

文章目录 前言1. 拦截器1.1 什么是拦截器1.2 拦截器的使用1.2.1 自定义拦截器1.2.2 注册配置拦截器 1.3 拦截器详解1.3.1 拦截路径1.3.2 拦截器执行流程1.3.3 适配器模式 2. 统一数据返回格式3. 统一异常处理 前言 在日常使用 Spring 框架进行开发的时候&#xff0c;对于一些板…

flutter给组件设置背景图的操作

可以设置背景图的组件只有一个&#xff0c;那就是Container容器&#xff0c;要想设置背景图&#xff0c;可以使用网路图片&#xff0c;也可以使用本地图片&#xff0c;要是使用本地图片&#xff0c;需要在本地添加一个资源路径&#xff0c;用来管理这些文件&#xff0c;在本地项…

若依框架实现排序【升序或降序】很简单

前端实现 1. 在表格上加监听函数sort-change。如下红框所示&#xff1a; 2. 在表行上加排序字:sort-orders&#xff0c;可排序字sortable。如下红框所示&#xff1a; 3. 添加监听函数实现。代码如下&#xff1a; handleSortChange(column) {this.queryParams.orderByColumn …

【深入理解 ByteBuf 之三 接口类拆解】2. Recycler 接口设计真正的回收机制

Recycler 回收器接口设计 本节接着 ObjectPool 的设计脉络&#xff0c;具体看看其具体实现 RecyclerObjectPool 中引用的 Recycler 究竟是怎么实现的 这一张图基本已经说明白了&#xff0c;我再做个总结&#xff0c;对细节感兴趣的可以看看我下面带源码的注释。 对于 Recycle…

debian 11 arm64 aarch64 源码变异winehq arm64 笔记

安装华为毕昇编译器 sudo apt install libc1-13 编译tools cd tools su root export PATH/opt/bisheng-compiler-1.3.3-aarch64-linux/bin:$PATH rootdebian:/home/yeqiang/下载/src/wine/tools# ../configure CC/opt/bisheng-compiler-1.3.3-aarch64-linux/bin/clang C…

职场硬货:刚入职面对陌生的被测系统, 没有需求文档如何快速熟悉?

各位小伙伴大家好, 今天为大家分析一下在企业中, 如果快速的上手被测系统/软件, 了解产品目标业务需求, 做到尽快尽职完成测试工作。 找到所有可能的相关文档 尽可能找到项目开发计划书, 项目签订的合同, 一般合同中会包含项目研发背景, 与产品及功能点概述, 这样可以先了解项…

一文速学-selenium高阶性能优化技巧

一文速学-selenium高阶性能优化技巧 前言 最近写的挺多自动化办公的selenium程序没有做优化&#xff0c;执行效率不高&#xff0c;启动浏览器又慢但是又可能出现其他不可控的因素&#xff0c;总结来说虽然放心运行但是又没那么好用&#xff0c;项目是写完了最后还是需要优化结…

Hive分区表实战 - 多分区字段

文章目录 一、实战概述二、实战步骤&#xff08;一&#xff09;创建学校数据库&#xff08;二&#xff09;创建省市分区的大学表&#xff08;三&#xff09;在本地创建数据文件1、创建四川成都学校数据文件2、创建四川泸州学校数据文件3、创建江苏南京学校数据文件4、创建江苏苏…

在线项目实习|2024寒假项目实战火热报名中!

一、在线实习项目分类 二、在线实习项目流程 三、在线实习项目优惠及项目特色 1、师傅带练教学模式&#xff0c;手把手教你掌握 采用“师带徒”的教学模式&#xff0c;课程以“项目前置知识学习 师傅带练 项目实战”贯穿&#xff0c;强调动手实操&#xff0c;内容以代码落地为…

反向代理的本质是什么?

反向代理是一种网络架构模式&#xff0c;通常用于提供静态内容、处理安全、负载均衡和缓存等任务。在这种架构中&#xff0c;客户端发送的请求首先到达反向代理服务器&#xff0c;然后由反向代理服务器将请求转发给后端的实际服务器。反向代理服务器可以处理和修改请求和响应&a…

命名空间 “Eigen“ 没有成员 “SelfAdjointEigenSolver“

代码中用到SelfAdjointEigenSolver 结果报错&#xff1a;报错实在windows10条件下发生的。 查找资料&#xff0c;最后还是要定位到官方文档。 计算自伴随矩阵的特征值和特征向量。 这是在特征值模块中定义的。 添加如下引用即可解决&#xff0c;请点赞关注。 #include <…