C++基础知识(八:STL标准库(Vectors和list))

news2024/11/16 3:46:13

C++ STL (Standard Template Library标准模板库) 是通用类模板和算法的集合,它提供给程序员一些标准的数据结构的实现如 queues(队列), lists(链表), 和 stacks(栈)等.

STL容器的提供是为了让开发者可以更高效率的去开发,同时我们应该也需要知道他们的底层实现,这样在出现错误的时候我们才知道一些原因,才可以更好的去解决问题。

C++ STL 提供给程序员以下三类数据结构的实现:

  • 顺序结构  C++ Vectors  
    • C++ Lists  
    • C++ Double-Ended Queues 
  • 容器适配器  C++ Stacks  
    • C++ Queues  
    • C++ Priority Queues 
  • 联合容器  C++ Bitsets  
    • C++ Maps  
    • C++ Multimaps  
    • C++ Sets  
    • C++ Multisets 

【1】Vectors容器

vector的行为和数组类似,可以理解为顺序表

vector不需要判满,动态分配内存:如果存入新的数据,会再开辟一片更大的空间,把原来的内容拷贝过去

begin和end成员函数,返回起始位置和结尾位置的迭代器

front和back函数,返回起始位置和结尾位置的引用

1bool empty();
如果当前vector没有容纳任何元素,empty()函数返回true,否则返回false
2、size_type size();
size() 函数返回当前vector所容纳元素的数目
3、TYPE at( size_type loc );
at() 函数 返回当前Vector指定位置loc的元素的引用. at() 函数 比 [] 运算符更加安全, 因为它不会让你去访问到Vector内越界的元素
4、iterator begin();
begin()函数返回一个指向当前vector起始元素的迭代器
5、iterator end();
end() 函数返回一个指向当前vector末尾元素的下一位置的迭代器
6void push_back( const TYPE &val );
push_back()添加值为val的元素到当前vector末尾
7、size_type capacity();
capacity() 函数 返回当前vector在重新进行内存分配以前所能容纳的元素数量.
vector容器,会二倍扩容(如果当前容器的空间全部被占用了,再插入元素时,会按照此刻vector容器的空间进行二倍扩容)
8、TYPE front();
front()函数返回当前vector起始元素的引用
9、iterator insert( iterator loc, const TYPE &val );
在指定迭代器的前一个位置插入
10、 void assign( input_iterator start, input_iterator end );
给容器中的元素赋

找指定位置的迭代器:

由于容器类,只提供了找起始位置和结束位置的迭代器,所以找指定位置的迭代器,只能在已有迭代器的位置上自增,和指针的行为类似,访问元素需要解引用,但是不能和指针类型强转

容器名<数据类型> ::iterator  迭代器名;

vector会二倍扩容(代码中有详细注释)

【2】list容器

STL list 容器,又称双向链表容器,即该容器的底层是以双向链表的形式实现的。这意味着,list 容器中的元素可以分散存储在内存空间里,而不是必须存储在一整块连续的内存空间中。

1. begin()	
返回指向容器中第一个元素的双向迭代器。
2. end()	
返回指向容器中最后一个元素所在位置的下一个位置的双向迭代器。
3. rbegin()	
返回指向最后一个元素的反向双向迭代器。
4. rend()	
返回指向第一个元素所在位置前一个位置的反向双向迭代器。
5. cbegin()	
和 begin() 功能相同,只不过在其基础上,增加了 const 属性,不能用于修改元素。
6. cend()	
和 end() 功能相同,只不过在其基础上,增加了 const 属性,不能用于修改元素。
7. crbegin() 	
和 rbegin() 功能相同,只不过在其基础上,增加了 const 属性,不能用于修改元素。
8. crend()	
和 rend() 功能相同,只不过在其基础上,增加了 const 属性,不能用于修改元素。
9. empty()	
判断容器中是否有元素,若无元素,则返回 true;反之,返回 false。
10. size()	
返回当前容器实际包含的元素个数。
11. max_size()	
返回容器所能包含元素个数的最大值。这通常是一个很大的值,一般是 232-1,所以我们很少会用到这个函数。
12. front()	
返回第一个元素的引用。
13. back()	
返回最后一个元素的引用。
14. assign()	
用新元素替换容器中原有内容。
15. emplace_front()	
在容器头部生成一个元素。该函数和 push_front() 的功能相同,但效率更高。
16. push_front()	
在容器头部插入一个元素。
17. pop_front()	
删除容器头部的一个元素。
18. emplace_back()	
在容器尾部直接生成一个元素。该函数和 push_back() 的功能相同,但效率更高。
19. push_back()	
在容器尾部插入一个元素。
20. pop_back()	
删除容器尾部的一个元素。
21. emplace()	
在容器中的指定位置插入元素。该函数和 insert() 功能相同,但效率更高。
22. insert() 	
在容器中的指定位置插入元素。
23. erase()	
删除容器中一个或某区域内的元素。
24. swap()	
交换两个容器中的元素,必须保证这两个容器中存储的元素类型是相同的。
25. resize()	
调整容器的大小。
26. clear()	
删除容器存储的所有元素。
27. splice()	
将一个 list 容器中的元素插入到另一个容器的指定位置。
28. remove(val)
删除容器中所有等于 val 的元素。
29. remove_if()	
删除容器中满足条件的元素。
30. unique()	
删除容器中相邻的重复元素,只保留一个。
31. merge()	
合并两个事先已排好序的 list 容器,并且合并之后的 list 容器依然是有序的。
32. sort()	
通过更改容器中元素的位置,将它们进行排序。
33. reverse()	
反转容器中元素的顺序。1

由此可以理解,list 容器中各个元素的前后顺序是靠指针来维系的,每个元素都配备了 2 个指针,分别指向它的前一个元素和后一个元素。其中第一个元素的前向指针总为 null,因为它前面没有元素;同样,尾部元素的后向指针也总为 null。

这大概就是双向链表的样子,正常的链表只有一个指针指向他的下一个元素,而双向就是再单向的前提上加上一个指针,指向他前面的元素。

基于这样的存储结构,list 容器具有一些其它容器(array、vector 和 deque)所不具备的优势,即它可以在序列已知的任何位置快速插入或删除元素(时间复杂度为O(1))。并且在 list 容器中移动元素,也比其它容器的效率高。

使用 list 容器的缺点是,它不能像 array 和 vector 那样,通过位置直接访问元素。举个例子,如果要访问 list 容器中的第 6 个元素,它不支持容器对象名[6]这种语法格式,正确的做法是从容器中第一个元素或最后一个元素开始遍历容器,直到找到该位置。

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

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

相关文章

Vue——携带参数跳转路由

Vue学习之——跳转路由 前情回顾 当我们进行点击修改时&#xff0c;会进行跳转到修改页面&#xff0c;为了完成回显数据&#xff08;根据对应id查找&#xff09;&#xff0c;我们需要携带对应选择中的id跳转到修改页面&#xff0c;让其进行查找回显 学习useRoute和useRoute…

【Redis】深入理解 Redis 常用数据类型源码及底层实现(6.详解Set和ZSet数据结构)

本文是深入理解 Redis 常用数据类型源码及底层实现系列的第6篇&#xff5e;前5篇可移步(&#xffe3;∇&#xffe3;)/ 【Redis】深入理解 Redis 常用数据类型源码及底层实现&#xff08;1.结构与源码概述&#xff09;-CSDN博客 【Redis】深入理解 Redis 常用数据类型源码及底…

CCDP.01.寄主机SSH连接虚拟机的QA

V0.0 初始版本-2024.2.29 检查VM的网卡配置 如上图&#xff0c;如果enp0s3网卡没有出现形如10.0.0.??/24的ip配置&#xff0c;说明该网卡配置存在错误&#xff0c;或者没有“使能”该网卡。在RockyLinux8.X中可检查“ifcfg-enp0s&#xff1f;” vi /etc/sysconfig/network-…

51-n皇后(回溯算法)

题目 按照国际象棋的规则&#xff0c;皇后可以攻击与之处在同一行或同一列或同一斜线上的棋子。 n 皇后问题 研究的是如何将 n 个皇后放置在 nn 的棋盘上&#xff0c;并且使皇后彼此之间不能相互攻击。 给你一个整数 n &#xff0c;返回所有不同的 n 皇后问题 的解决方案。 每一…

C# Post数据或文件到指定的服务器进行接收

目录 应用场景 实现原理 实现代码 PostAnyWhere类 ashx文件部署 小结 应用场景 不同的接口服务器处理不同的应用&#xff0c;我们会在实际应用中将A服务器的数据提交给B服务器进行数据接收并处理业务。 比如我们想要处理一个OFFICE文件&#xff0c;由用户上传到A服务器…

【CesiumJS-3】加载倾斜模型数据(3DTilest)以及修改位置

引入倾斜模型数据 // 加载3DTiles数据let tileset;try {tileset await Cesium.Cesium3DTileset.fromUrl("/api/3DTiles/b3dm_qx/tileset.json");viewer.value.scene.primitives.add(tileset); // 倾斜模型添加到场景中viewer.value.zoomTo(tileset); // 视角定位到倾…

外汇天眼:2月客诉TOP10榜单公布,快来看看你用的平台有没有上榜!

作为外汇投资者了解每个月登上客诉榜单的交易平台很重要&#xff0c;只有这样才能有效的预防自己遭遇外汇黑平台&#xff0c;也能警觉的提前发现平台的异常&#xff0c;对于自己的外汇交易道路只有利无弊&#xff01; 快来看看有哪些平台上榜&#xff0c;你所使用的平台是否在…

3 局域网基础(1)

1.局域网 早期的局域网主要是令牌环网。20世纪80年代&#xff0c;局域网领域出现 Ethernet与Token Bus、Token Ring三足鼎立的局面&#xff0c;并且各自都形成了相应的国际标准。21 世纪&#xff0c;Ethernet 已成为局域网领域的主流技术。介质访问控制&#xff08;MAC&#xf…

破局数据分析滞后难题,赋能企业高速增长的指标管理解决方案

指标是什么&#xff1f; 业务发展过程中&#xff0c;企业内外部都会产生很多的业务数据&#xff0c;对这些数据进行采集、计算、落库、分析后&#xff0c;形成的统计结果称为指标。简单来说&#xff0c;指标是业务被拆解、量化后形成的数量特征&#xff0c;企业利用数据指标对…

如何使用Portainer创建Nginx容器并搭建web网站发布至公网可访问【内网穿透】

文章目录 前言1. 安装Portainer1.1 访问Portainer Web界面 2. 使用Portainer创建Nginx容器3. 将Web静态站点实现公网访问4. 配置Web站点公网访问地址4.1公网访问Web站点 5. 固定Web静态站点公网地址6. 固定公网地址访问Web静态站点 前言 Portainer是一个开源的Docker轻量级可视…

【PyTorch][chapter 18][李宏毅深度学习]【无监督学习][ VAE]

前言: VAE——Variational Auto-Encoder&#xff0c;变分自编码器&#xff0c;是由 Kingma 等人于 2014 年提出的基于变分贝叶斯&#xff08;Variational Bayes&#xff0c;VB&#xff09;推断的生成式网络结构。与传统的自编码器通过数值的方式描述潜在空间不同&#xff0c;它…

用JavaScript动态提取视频中的文字

现阶段整个社会短视频&#xff0c;中视频为王&#xff0c;文字传播虽然被弱化&#xff0c;但在业务中还是有一定的传播价值&#xff0c;今天就来讲一讲如何使用js动态提取视频中的字幕。 先来看看效果&#xff1a; 屏幕录制2024-02-29 15.40.18 一&#xff0c;tesseract.js介…

springcloud alibaba组件简介

一、Nacos 服务注册中心/统一配置中心 1、介绍 Nacos是一个配置中心&#xff0c;也是一个服务注册与发现中心。 1.1、配置中心的好处&#xff1a; &#xff08;1&#xff09;配置数据脱敏 &#xff08;2&#xff09;防止出错&#xff0c;方便管理 &#xff08;3&#xff…

Web漏扫工具OWASP ZAP安装与使用(非常详细)从零基础入门到精通,看完这一篇就够了。

本文仅用于安全学习使用&#xff01;切勿非法用途。 一、OWASP ZAP简介 开放式Web应用程序安全项目&#xff08;OWASP&#xff0c;Open Web Application Security Project&#xff09;是一个组织&#xff0c;它提供有关计算机和互联网应用程序的公正、实际、有成本效益的信息。…

javascript作用域编译浅析

作用域思维导图 1&#xff1a;编译原理 分词/词法分析 如果词法单元生成器在判断a是一个独立的词法单元还是其他词法单元的一部分时&#xff0c;调用的是有状态的解析规则&#xff0c;那么这个过程就被称为词法分析。 解析/语法分析 由词法单元流转换成一个由元素逐级嵌套所组…

java: 错误: 不支持发行版本 5

目录 一、问题描述 二、解决办法 方法一&#xff1a;修改idea设置中的jdk版本 方法二&#xff1a;配置pom.xml文件 方法三&#xff1a;配置maven的xml文件&#xff08;推荐&#xff09; 三、结果 一、问题描述 问题描述&#xff1a;今天创建了一个maven项目&#xff0c;…

第六课:NIO简介

一、传统BIO的缺点 BIO属于同步阻塞行IO,在服务器的实现模型为&#xff0c;每一个连接都要对应一个线程。当客户端有连接请求的时候&#xff0c;服务器端需要启动一个新的线程与之对应处理&#xff0c;这个模型有很多缺陷。当客户端不做出进一步IO请求的时候&#xff0c;服务器…

Gitlab: 私有化部署

目录 1. 说明 2. 资源要求 3. 安装 4. 配置实践 4.1 服务器 4.2 人员与项目 4.2 部署准备 4.2.1 访问变量及用户账号设置 4.2.2 Runner设置 4.2.3 要点 5. 应用项目 CI/CD 6. 参考 1. 说明 gitlab是一个强大且免费的代码管理/部署工具&#xff0c;能统一集成代码仓…

springboot233大学生就业需求分析系统

大学生就业需求分析系统设计与实现 摘 要 信息数据从传统到当代&#xff0c;是一直在变革当中&#xff0c;突如其来的互联网让传统的信息管理看到了革命性的曙光&#xff0c;因为传统信息管理从时效性&#xff0c;还是安全性&#xff0c;还是可操作性等各个方面来讲&#xff…

SpringBoot接收参数的几种形式

SpringBoot接收参数的几种形式 在SpringBoot中获取参数基本方式有5种,需要都掌握. 这里需要记住一个技术术语或概念 API接口: 你写好的那个URL地址,就被称为API接口 1. 接收常规参数 给/param/demo1这个URL接口发送id, name两个参数 以上是以GET请求类型进行发送,实际发送…