STL
文章平均质量分 97
STL标准模板库知识分享
ephemerals__
大二在读学生,平时会分享一些关于编程的技术和知识,希望可以和大家一起学习讨论,共同进步。专注领域:C/C++
展开
-
【c++丨STL】priority_queue(优先级队列)的使用与模拟实现
优先级队列是一种容器适配器,根据某种严格的弱排序标准,特别设计为它的第一个元素总是它所包含的元素中的最大元素。虽然它的名字叫“优先级队列”,但实际上它跟队列没有什么关系,它的底层结构是堆。既然它的底层结构是一个堆,那么它也就符合堆的所有性质,例如不能遍历、只能从堆顶出入数据等。原创 2024-11-21 22:25:15 · 1029 阅读 · 17 评论 -
【c++丨STL】stack和queue的使用及模拟实现
与vector、list这些容器不同,stack和queue被称作容器适配器。所谓容器适配器,就是指在一种已有的容器基础上,为其添加了一些新的特性或者功能,目的是使一事物的行为类似于另一类事物。比如说栈这一数据结构,它的本质其实就是对顺序表或者链表的功能进行了一些限制,例如无法遍历、只能在一端进出数据等,但其底层仍然是顺序结构或是链式结构。STL在设计stack和queue时,并没有从零开始构建它们的底层结构,而是采用了这种设计思想,对现有容器进行了封装,从而实现了它们。原创 2024-11-20 19:56:41 · 1210 阅读 · 23 评论 -
【c++丨STL】list模拟实现(附源码)
本篇文章,我们在掌握list使用方法及其底层原理的基础上,模拟实现出了list容器。由于底层数据内存的非连续性,它的迭代器实现与vector、string有较大差异。原创 2024-11-19 22:00:42 · 970 阅读 · 21 评论 -
【c++丨STL】list的使用
之前我们已经学习了string、vector两个容器的使用方法及模拟实现,今天跟大家介绍list的使用方法。在STL中,尽管容器各异,但同名接口的功能往往是相似的。因此,在我们掌握了少数几个容器的使用方法后,对于未曾接触过的其他容器,只要了解其底层数据结构,就基本能够上手使用它们。list是STL中的一种容器,用于表示链表结构,底层实现是一个双向带头循环链表。原创 2024-11-13 21:36:24 · 1450 阅读 · 29 评论 -
【c++丨STL】vector模拟实现
与传统的动态顺序表不同,它采用了三个迭代器来维护数组,提高了程序灵活性。也正因如此,它的实现难度也有所增大,对于细节把控的要求也很高。原创 2024-11-09 19:16:15 · 1317 阅读 · 24 评论 -
【c++丨STL】vector的使用
vector是STL中的一种容器,它用于表示可变大小的数组,底层使用动态顺序表实现。相比传统的数组,vector附带了一系列操作接口,并且由于内存是动态分配的,所以不必担心插入元素时内存不足的问题。由于vector强大的功能和灵活性,我们在c++编程中经常使用vector来表示内存连续的序列。我们使用vector时,要引头文件,并且该容器定义在命名空间std当中。今天我们学习了STL另一个容器--vector的使用。不难发现,原创 2024-11-06 22:49:14 · 1107 阅读 · 21 评论 -
【c++丨STL】string模拟实现(附源码)
今天,我们在学会使用string类的基础上模拟实现了string类的常用功能,这对于我们学习数据结构和string类有很大帮助。之后博主会和大家一起进入下一个容器——vector的学习。原创 2024-10-24 15:38:23 · 1575 阅读 · 31 评论 -
【c++丨STL】string类的使用
今天,我们正式进入了STL的大门,学习了第一个容器——string。string虽然接口较多,但是它的实用性很高,为我们处理字符串提供了很多便利。由于其中一些接口并不是很常用,博主就没有过多赘述,大家可以在cplusplus官网进一步了解它们。之后博主会和大家一起,在熟练运用的基础上,深入其底层,并尝试模拟实现string类。原创 2024-10-20 01:26:38 · 1191 阅读 · 35 评论 -
【c++】STL简介
STL(Standard Template Library,标准模板库),是c++标准库的一个重要组成部分,它提供了一系列通用的类模板和函数,是一个包罗数据结构和算法的软件框架。STL的出现弥补了c++开发效率的不足,大大提高了程序的可复用性。原创 2024-09-21 17:36:18 · 1558 阅读 · 27 评论
分享