
STL
文章平均质量分 97
STL标准模板库知识分享
ephemerals__
大二在读学生,阿里云专家博主,腾讯云开发者社区入驻博主,华为云享专家,平时会分享一些关于编程的技术和知识,希望可以和大家一起学习讨论,共同进步。专注领域:C++
展开
专栏收录文章
- 默认排序
- 最新发布
- 最早发布
- 最多阅读
- 最少阅读
-
【c++丨STL】基于红黑树模拟实现set和map(附源码)
本篇文章,基于之前实现的红黑树代码,我们将仿照SGI STL的实现方式,尝试对同一棵红黑树进行封装和一系列适配修改,模拟实现set和map两种容器。原创 2025-02-13 16:29:02 · 1178 阅读 · 22 评论 -
【c++丨STL】map/multimap的使用
与set相同,map的底层也是基于红黑树实现的,其内部元素根据键自动升序排列。但两者有如下区别存储内容:set存储的是键,而map存储的是键值对(数据元素是一个pair。元素访问:set只能访问键,而map可以通过键来访问对应的值,并且值可以支持修改。因此,set适用于唯一元素的集合操作,如去重;而map更适用于处理键值关系。相比map,multimap支持多个相同键存在。原创 2025-01-19 17:47:59 · 1279 阅读 · 19 评论 -
【c++丨STL】set/multiset的使用
set(集合)和multiset(多重集合)是STL中的容器,分别用于处理唯一元素和允许重复元素的场景,它们的底层结构都是红黑树(一种自平衡二叉搜索树)。set和multiset有以下共同特点:1. 容器元素自动按照升序排列(也可通过传入第二个模板参数调整排序规则)。2. 元素插入、删除、查找的时间复杂度均为O(logN)。set和multiset的核心区别是:set不允许容器内有重复元素,能够达到去重的效果;而multiset支持插入重复元素。鉴于set和multiset的接口功能。原创 2024-12-20 19:22:09 · 1702 阅读 · 35 评论 -
【c++丨STL】priority_queue(优先级队列)的使用与模拟实现
优先级队列是一种容器适配器,根据某种严格的弱排序标准,特别设计为它的第一个元素总是它所包含的元素中的最大元素。虽然它的名字叫“优先级队列”,但实际上它跟队列没有什么关系,它的底层结构是堆。既然它的底层结构是一个堆,那么它也就符合堆的所有性质,例如不能遍历、只能从堆顶出入数据等。原创 2024-11-21 22:25:15 · 1395 阅读 · 22 评论 -
【c++丨STL】stack和queue的使用及模拟实现
与vector、list这些容器不同,stack和queue被称作容器适配器。所谓容器适配器,就是指在一种已有的容器基础上,为其添加了一些新的特性或者功能,目的是使一事物的行为类似于另一类事物。比如说栈这一数据结构,它的本质其实就是对顺序表或者链表的功能进行了一些限制,例如无法遍历、只能在一端进出数据等,但其底层仍然是顺序结构或是链式结构。STL在设计stack和queue时,并没有从零开始构建它们的底层结构,而是采用了这种设计思想,对现有容器进行了封装,从而实现了它们。原创 2024-11-20 19:56:41 · 1522 阅读 · 27 评论 -
【c++丨STL】list模拟实现(附源码)
本篇文章,我们在掌握list使用方法及其底层原理的基础上,模拟实现出了list容器。由于底层数据内存的非连续性,它的迭代器实现与vector、string有较大差异。原创 2024-11-19 22:00:42 · 1256 阅读 · 25 评论 -
【c++丨STL】list的使用
之前我们已经学习了string、vector两个容器的使用方法及模拟实现,今天跟大家介绍list的使用方法。在STL中,尽管容器各异,但同名接口的功能往往是相似的。因此,在我们掌握了少数几个容器的使用方法后,对于未曾接触过的其他容器,只要了解其底层数据结构,就基本能够上手使用它们。list是STL中的一种容器,用于表示链表结构,底层实现是一个双向带头循环链表。原创 2024-11-13 21:36:24 · 1754 阅读 · 32 评论 -
【c++丨STL】vector模拟实现
与传统的动态顺序表不同,它采用了三个迭代器来维护数组,提高了程序灵活性。也正因如此,它的实现难度也有所增大,对于细节把控的要求也很高。原创 2024-11-09 19:16:15 · 1556 阅读 · 24 评论 -
【c++丨STL】vector的使用
vector是STL中的一种容器,它用于表示可变大小的数组,底层使用动态顺序表实现。相比传统的数组,vector附带了一系列操作接口,并且由于内存是动态分配的,所以不必担心插入元素时内存不足的问题。由于vector强大的功能和灵活性,我们在c++编程中经常使用vector来表示内存连续的序列。我们使用vector时,要引头文件,并且该容器定义在命名空间std当中。今天我们学习了STL另一个容器--vector的使用。不难发现,原创 2024-11-06 22:49:14 · 1401 阅读 · 22 评论 -
【c++丨STL】string模拟实现(附源码)
今天,我们在学会使用string类的基础上模拟实现了string类的常用功能,这对于我们学习数据结构和string类有很大帮助。之后博主会和大家一起进入下一个容器——vector的学习。原创 2024-10-24 15:38:23 · 2017 阅读 · 32 评论 -
【c++丨STL】string类的使用
今天,我们正式进入了STL的大门,学习了第一个容器——string。string虽然接口较多,但是它的实用性很高,为我们处理字符串提供了很多便利。由于其中一些接口并不是很常用,博主就没有过多赘述,大家可以在cplusplus官网进一步了解它们。之后博主会和大家一起,在熟练运用的基础上,深入其底层,并尝试模拟实现string类。原创 2024-10-20 01:26:38 · 1460 阅读 · 38 评论 -
【c++】STL简介
STL(Standard Template Library,标准模板库),是c++标准库的一个重要组成部分,它提供了一系列通用的类模板和函数,是一个包罗数据结构和算法的软件框架。STL的出现弥补了c++开发效率的不足,大大提高了程序的可复用性。原创 2024-09-21 17:36:18 · 1932 阅读 · 28 评论