首页 > 编程语言 >C++ STL 容器底层实现

C++ STL 容器底层实现

时间:2023-11-17 21:14:34浏览次数:38  
标签:容器 头文件 STL C++ 链表 vector 节点 底层

一、关键词

I:容器

1、顺序容器:底层是链表和数组
    array(数组)、vector(可变数组)、deque(双端队列)
    forward_list(单向链表)、list(双向链表)
2、关联容器:底层是红黑树
    set(集合)、mulitset(可重复元素的集合)
    map(字典)、multimap(可重复键值的字典)
3、无序关联容器(哈希表)
    unordered_set(无序集)、unordered_multiset(可重复元素的无序集)
    unordered_map(无序字典)、unordered_multimap(可重复的无序字典)

II:容器适配器

stack(堆栈)、queue(队列)、priority_queue(优先级队列)

二:知识点

补充知识1:

逻辑结构:线性、图状、树、集合
存储结构:顺序、链式、索引、散列(hash)

补充知识2

关联容器底层是红黑树即二叉搜索树。红黑树满足如下规则:

    I:每个节点不是红色就是黑色;
    II:根节点(第一个节点)必为黑色;
    III:红色节点的子节点不能为红色;
    IV:任一节点至树尾端(null)的任何路径包含的黑色节点数必须相同。

注意:当新插入的节点不满足上述规则是,则需要调整颜色并旋转树形,使其仍保持上述性质的平衡二叉搜索树。红黑树是有二叉树发展而来:二叉树->二叉查找树->二叉平衡树->红黑树,所以继承了平衡二叉树的左边所有节点比根节点小,右边所有节点比根大。

1、array(数组)在头文件中,声明时确定容器大小。在声明时指定类型T与数组大小N,即array<int,5>。数组实现。

 性能:查找:array任意位置为O(1)。
      插入:末端O(1),其他位置O(n)
      删除:末端O(1),其他位置O(n)

2、vector(可变数组)在头文件中,动态数组,其中元素连续存储在一个内存中,但vector的内存大小是可变的--在初始分配的内存填满元素后再添加元素使,vector的alloter,会重新分配内存空间,一般是原来的2倍,各家调教不同,然后整体拷贝旧元素到新的内存空间中,这个步骤是运行期间自动完成的。指定类型即可,如vector,也可是自定的结构体等等。

 性能:查找:vector任意位置为O(1)。
      插入:末端O(1),其他位置O(n)
      删除:末端O(1),其他位置O(n)

3、deque(双端队列),特点是只在头尾两端进行操作。头文件为,即deque,T为类型。deque是双端队列,其底层实现是用一系列连续的固定大小的数组进行组合,给人以“我”是连续的内存空间的感觉,与vector相比,在数据量大的情况下更占优势。由中控器与缓冲器实现,中控器中的每个元素指向一段内存空间,所指向的内存空间即为缓冲器,缓冲器是用来存储数据的。需维护两个迭代器start和finish,分别指向第一个元素缓冲器的第一个元素和最后缓冲器的最后一个元素,此外俩个迭代器都指向中控器。

 性能:查找:--
      插入:头尾O(1)
      删除:头尾O(1)

4、forward_list(单向链表),数据只能进行单向访问,其头文件<forward_list>,即forward_list,需指定T存储类型。

 性能:查找:O(n)
      插入:头O(1),平均O(n)
      删除:头O(1),平均O(n)

5、list(双向链表),使用时包含头文件,环形双向链表,具有prev和next指针以及数据域data,分贝指向当前节点的前一个和后一个节点。链表的第一个node不存储数据,它的begin是从第二个node算起,链表最大的特点是大小可变切存储非连续,包含指针造成空间浪费。

     性能:查找:O(n)
      插入:O(1)
      删除:O(1)

6、 set(集合)底层数据结构为红黑树,头文件为,另外可提供compare函数,有默认比较函数,默认是升序。唯一键。

7、multiset(可重复元素的集合)底层红黑树,头文件为,与set类似,但其可以包含相同的键。

8、map(字典)底层数据结构为红黑树,字典中的键值具有唯一性。头文件为,需要指定key与value,如map<int,int>,同样可以指定compare函数,默认升序。

9、multimap(可重复键值的字典)底层红黑树,头文件,与map类似,区别是可以存储相同的键值,键值不具有唯一性。

三、实际运用

点击查看代码
//***

标签:容器,头文件,STL,C++,链表,vector,节点,底层
From: https://www.cnblogs.com/lvshen/p/17839484.html

相关文章

  • C++线程
    进程以CPU为运行单位,多个CPU可以实现进程并行,单个CPU可以实现进程并发(进程调度)线程以CPU的核心为运行单位,多个CPU内核可以实现线程并行,单个内核可以实现线程并发(线程调度)1、创建和结束一个线程 #include<iostream>#include<pthread.h>///@brief创建一个线程///@param......
  • C++类与继承
    C++类有三种访问修饰符:public(共有的)、private(私有的)、protected(受保护的)类内各区域成员的访问:1、public类内成员函数、类外、友元函数都可以访问。2、private类内成员函数、友元函数可以访问,private区域成员不能在派生类中访问。3、protected与private不同之......
  • 【笔记】 STL容器
    【笔记】STL容器vector vector<int>v; v.push_back(x); v.emplace(x); v.size(); v.erase(v.begin(),v.begin()+pos); v.insert(v.begin()+pos,x); lower_bound(v.begin(),v.end())-v.begin(); v.clear();bitsetbitset<8>s("00011011");......
  • 第十四届蓝桥杯省赛 C++B组 ---- 景区导游
    第十四届蓝桥杯省赛C++B组----景区导游LCA原题连接​ lca同时得到按原来路径走的总时间​ 最后输出时处理跳过某个点的时间​ 预处理用bfs或dfs都可以importjava.io.BufferedReader;importjava.io.InputStreamReader;importjava.util.Arrays;importjava.......
  • C++ 指针学习笔记
    C++指针学习笔记引入指针是什么指针是一个变量,其值为另一个变量的地址。指针声明的一般形式为:type*ptr_name;type是指针的基类型,ptr_name是指针的名称,*用来指定一个变量是指针对于一个指针,需要明确四个方面的内容:指针的类型、指针所指向的类型、指针的值(指针所指向的......
  • C++从零复习
    0.前言子曰:“温故而知新,可以为师矣。”学习了知识,不复习怎么行。这篇随笔是为C++小白写的复习资料,根据目录使用效果更佳。悄悄告诉你:听课的时候走神了也可以查缺补漏哦1.顺序结构(1)框架头文件#include<clude_name>//将名为“clude_name”的头文件导入//常用头文件实例#i......
  • C++ STL String用法
    string在C语言中,提供了字符串的操作,但只能通过字符数组的方式来实现字符串。而string则是一个简单的类,使用简单,在OI竞赛中被广泛使用。相较于其他STL容器,string的常数可以算是非常优秀的,基本与字符数组不相上下。string常用操作输出strings="123";printf("%s......
  • 【C++中cin在Qt输出终端无法手动输入问题解决办法(详细)】
    现象:在Qt中使用cin进行对一个变量z进行输入,然后在用cout对z进行输出,结果没有进行手动输入,程序自动凭空出现类似512,32759等一些数值输出。 解决办法:第一步:在Qt左侧项目栏,在.pro文件中添加一行代码CONFIG+=console 第二步:在项目--运行--勾选在终端中运行(Runinterminal) 配置......
  • KubeSphere开源容器自动化运维平台实现远程访问操作,解决本地限制
    KubeSphere是一个基于Kubernetes的开源容器平台,它提供了全栈的IT自动化运维能力,简化了企业的DevOps工作流。KubeSphere采用前后端分离的架构,可以运行在任何Kubernetes、私有云、公有云、VM或物理环境之上。KubeSphere提供了运维友好的向导式操作界面,帮助企业快速构建一个强大和功......
  • C++笔记
    inline内联函数:内存膨胀,空间换时间,节省调用函数,给被调函数形参赋值以及自动回收内存的时间使用原则:内联函数内不要有循环,使用重复率较高,代码比较简单的函数使用内联函数引用(别名,解析引用符)int&dd=numdd与num共享同一段内存,定义引用必须赋初始值,引用的作用可以缩短名称......