STL中vector、list、map和set的主要区别

在C++的STL(Standard Template Library)中,vectorlistmapset是四种常用的容器,它们各自具有不同的特性和用途。以下是它们之间的主要区别:

  1. vector(向量)
    • 存储方式vector是一个动态数组,它在内存中连续存储元素。
    • 访问速度:由于vector的元素在内存中连续存储,因此可以通过索引快速访问任何元素(常数时间复杂度O(1))。
    • 插入/删除操作:在vector的末尾插入或删除元素是高效的(常数时间复杂度O(1)),但在其他位置插入或删除元素可能需要移动大量元素(线性时间复杂度O(n))。
    • 迭代器稳定性vector的迭代器在插入或删除操作后可能会失效,因为这些操作可能会导致内存重新分配和元素移动。
  2. list(链表)
    • 存储方式list是一个双向链表,它的元素在内存中不一定是连续的。
    • 访问速度:访问list中的特定元素相对较慢,因为需要从头或尾开始遍历链表(线性时间复杂度O(n))。
    • 插入/删除操作:在list中的任何位置插入或删除元素都是高效的(常数时间复杂度O(1)),因为只需要更改相关节点的指针。
    • 迭代器稳定性list的迭代器在插入或删除操作后仍然是有效的,因为这些操作不会移动其他元素。
  3. map(映射)
    • 存储方式map是一个关联容器,它包含可以重复的键值对,但每个键是唯一的。map通常使用一个红黑树来实现,因此元素在内存中不是连续存储的。
    • 访问速度:访问map中的元素(通过键)是高效的(对数时间复杂度O(log n))。
    • 插入/删除操作:在map中插入或删除元素是高效的(对数时间复杂度O(log n))。
    • 迭代器稳定性map的迭代器在插入或删除操作后可能会失效,因为这些操作可能会导致树的重新平衡。
  4. set(集合)
    • 存储方式set是一个关联容器,它包含唯一的元素。与map类似,set也通常使用红黑树来实现,因此元素在内存中不是连续存储的。
    • 访问速度:访问set中的元素(通过迭代器)是高效的,但直接通过值访问元素通常不是高效的(需要遍历集合)。
    • 插入/删除操作:在set中插入或删除元素是高效的(对数时间复杂度O(log n))。
    • 迭代器稳定性:与map相同,set的迭代器在插入或删除操作后可能会失效。

总结:

  • 如果你需要快速访问元素(通过索引),并且不关心插入/删除操作的性能,那么vector可能是最佳选择。
  • 如果你需要在任何位置频繁插入或删除元素,并且不关心直接访问性能,那么list可能更适合。
  • 如果你需要基于键存储和检索值(如字典或哈希表),那么map是最佳选择。
  • 如果你只需要存储唯一的元素,并且不关心直接访问性能,那么set可能更适合。

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

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

相关文章

AMBA-CHI协议详解(三)

《AMBA 5 CHI Architecture Specification》 AMBA-CHI协议详解(一) AMBA-CHI协议详解(二) AMBA-CHI协议详解(三) AMBA-CHI协议详解(四) 文章目录 2.3.2 Write transactions2.3.2.1 …

keil5显示内存和存储占用百分比进度条工具

简介 [Keil5_disp_size_bar] 以进度条百分比来显示keil编译后生成的固件对芯片的内存ram和存储flash的占用情况, 并生成各个源码文件对ram和flash的占比整合排序后的map信息的表格和饼图。 原理是使用C语言遍历当前目录找到keil工程和编译后生成的map文件 然后读取工程文件和m…

C++ 新特性 | C++ 11 | typename关键字

文章目录 一、typename关键字 前言: 在C的模板编程中,typename关键字扮演着至关重要的角色。它主要用于指示编译器将一个特定的标识符解释为类型名称,而不是变量名或其他实体。本文将深入探讨typename的用法,帮助读者更好地理解其…

若依框架自定义开发使用学习笔记(1)

因为我是跳着学的,原理那些都没咋看。 代码自动生成,依赖sql表 在ruoyi数据库中,创建你想要的表,这里我创建了个购物车表,由于空间有限,只能拍到这么多。 然后就可以在前端自动生成代码 点击导入按钮 …

创新入门 | 病毒循环Viral Loop是什么?为何能实现指数增长

今天,很多高速增长的成功创业公司都在采用”病毒循环“的策略去快速传播、并扩大用户基础。究竟什么是“病毒循环”?初创公司的创始人为何需要重视这个策略?这篇文章中将会一一解答与病毒循环有关的各种问题。 一、什么是病毒循环&#xff08…

【Ruby基础01】windows和termux中搭建Ruby开发环境

windows下环境搭建 railsinstaller官方git地址 按照文档安装git、nodejs、yarn,安装教程百度一下。railsinstall可以从release页面下载最新版本4.1.0。 安装完成如下 安装RubyMine 下载RubyMine RubyMine下载地址 安装激活 下载文件,按照里面的流程…

Java 读取Excel导入数据库,形成树状结构

最近开发过程中遇到一个Excel的导入的功能,因为导入的数据结构具有层次结构,经过一番研究,最终得以实现,所有写下该文章,记录过程,供以后参考。 下图是导入Excel的数据结构: 使用POI解析Excel,数据封装然后进行入库。下面是核心代码。 @Overridepublic KnowledgeBase…

示例:WPF中如何不卡顿页面的情况加载大量数据

一、目的:在开发过程中经常会遇到一个ListBox列表里面需要加载大量数据,但是加载过程中会假死卡顿影响用户体验,或者是你的主页面加载了大量控件,或者切换到一个有大量元素的页面都会有这种体验,因为加载的都是UI元素不…

基于matlab的RRT算法路径规划(附带案例源码)

文章中的所有案例均为博主手动复现,用于记录博主学习路径规划的过程,如有不妥,欢迎在评论区交流 目录 1 标准RRT1.1 算法原理1.2 演示 2 GBRRT2.1 算法原理2.2 算法演示 3 RRT-STAR3.1 算法原理3.2 算法演示 4 RRT-CONNECT4.1 算法原理4.2 算…

流量有限、日活低的APP适合对接广告变现吗?

APP广告变现,总用户数和日活用户(DUA)是衡量APP价值和影响力的重要指标之一。 APP DUA过万,尤其是大几万时,通常具备了商业化价值,适合接入广告变现。日活1W意味着每天有1万名用户在使用这款应用&#xff…

了解指标体系1:指标是大数据开发中的关键要素

在大数据开发的过程中,指标体系是一个至关重要的概念。本文将介绍什么是指标,为什么它们如此重要,以及如何在大数据项目中有效地构建和应用指标体系。 目录 什么是指标?指标的类型为什么指标如此重要?如何构建有效的指…

Leetcode Java学习记录——代码随想录链表篇

文章目录 链表定义移除链表的倒数第n个结点判断[列表是否有环](https://leetcode.cn/problems/linked-list-cycle-ii/description/)报错java.lang.StackOverflowError空指针异常 链表定义 public class ListNode{int val;ListNode next;//三种构造函数public ListNode(){}publ…

Swift开发——存储属性与计算属性

Swift语言开发者建议程序设计者多用结构体开发应用程序。在Swift语言中,结构体具有了很多类的特性(除类的与继承相关的特性外),具有属性和方法,且为值类型。所谓的属性是指结构体中的变量或常量,所谓的方法是指结构体中的函数。在结构体中使用属性和方法是因为:①匹别于结…

宋老师讲课技巧笔记

1 如何发声 •发声的重要性 •上课三要素: 外表, 声音, 板书(PPT) •如何科学发声 ​ 反例:如果只用喉咙, 会很累 ​ 要点:发声从胸口开始进行发声 ​ 升级: 从腹腔,到胸膛,到喉咙发声, …

每日一练:攻防世界:miao~

给了一张jpg图片 没发现什么特别,放到winhex中查看也没思路。 放到kali里面foremost分离文件试试,结果分离出个wav音频文件 直接放到 audycity看看频谱图 发现字符串,但是没有其他信息。可能是密钥之类的。到这里我就卡住了,看…

镜像拉取失败:[ERROR] Failed to pull docker image

问题描述 执行 bash docker/scripts/dev_start.sh 命令提示错误: permission denied while trying to connect to the Docker daemon socket at unix:///var/run/docker.sock: Post “http://%2Fvar%2Frun%2Fdocker.sock/v1.45/images/create?fromImageregistry.b…

微信小程序-上拉加载和下拉刷新

一.上拉加载 微信小程序的上拉加载使用onReachBottom(),写在.js文件里面的Page方法里面。 onReachBottom(){//上拉自动更新到4,5,6wx.showLoading({title: 数据加载中...,})setTimeout(()>{const lastNumthis.data.numList[this.data.nu…

webpack 中 require.context() 的用法

一、什么是 require.context It allows you to pass in a directory to search, a flag indicating whether subdirectories should be searched too, and a regular expression to match files against. – webpack 官方说明 一个 webpack 的 api ,通过该函数可以获…

类加载机制-打破双亲委派机制

文章目录 类加载机制打破打破双亲委派机制例子1例子2 类加载机制 类加载机制 打破打破双亲委派机制 例子1 JDBC的加载机制 Driver 接口是在rt.jar 包里定义的 public interface Driver {Connection connect(String url, java.util.Properties info)throws SQLException; }…

Java中Cookie的用法

Cookie是一段不超过4KB的小型文本数据,由一个名称(Name)、一个值(Value)和其它几个用于控制Cookie有效期、安全性、使用范围的可选属性组成。 Expires(过期) 设置Cookie的生存期。有两种存储类…