C++ 介绍STL底层一些数据结构

c++ 标准模板库中,set和map的底层实现通常基于红黑树,然们都是平衡二叉搜索树(Balanceed Binary Serach Tree) 的一种**,**这种结构保证了 插入,删除,查找的时间复杂度为O(log n)比普通二叉搜索树更高效。

set

set<T>是一个有序集合,不允许重复元素。

内部使用红黑树进行管理,每次插入时会自动排序。

set<T>是map<T,bool>的简化版,因为它只存储键,没有值。

map

map<Key,Value>是键值对(Key-Value结构),类似python字典。

底层也是红黑树,键(Key)作为排序的依据,值(Value)存储在节点上。

插入,查找时,树自动平衡,保持O(logn)复杂度。

unordermap一般是指无序映射,元素的存储顺序与插入顺序无关,由哈希函数决定。避免了map使用红黑树的O(log n)复杂度。唯一键。

unoedered_set 元素存储顺序由哈希函数决定,不能按照插入顺序或者大小顺序访问。

唯一性,集合中不能重复。比红黑树set更快,查找,插入,删除,平均O(1),不能直接修改集合中的元素值,但可以删除后重新插入。

相关推荐
逝雪Yuki2 分钟前
Leetcode——11. 盛最多水的容器
c++·算法·leetcode·双指针
小徐不徐说20 分钟前
深入理解 Qt 信号与槽机制的底层逻辑
数据库·c++·qt·面试
大梦谁先行27 分钟前
Qt写游戏脚本/辅助(仅供参考)
c++·qt·游戏
阳光_你好41 分钟前
C++中析构函数为什么需要是虚函数
c++
小乖兽技术1 小时前
C#与C++交互开发系列(二十六):构建跨语言共享缓存,实现键值对读写与数据同步(实践方案)
c++·c#·交互
mrbone111 小时前
C++-关于协程的一些思考
开发语言·数据库·c++·c++20·协程·异步·coroutines
朝朝又沐沐10 小时前
算法竞赛阶段二-数据结构(36)数据结构双向链表模拟实现
开发语言·数据结构·c++·算法·链表
逝雪Yuki11 小时前
Leetcode——287. 寻找重复数
c++·leetcode·二分查找·双指针·环形链表
李永奉12 小时前
C语言-流程控制语句:for循环语句、while和do…while循环语句;
c语言·开发语言·c++·算法
打码农的篮球12 小时前
STL——list
开发语言·c++·list