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),不能直接修改集合中的元素值,但可以删除后重新插入。

相关推荐
Mr_WangAndy10 分钟前
C++14新特性_第一章C++语言特性_Lambda初始化捕获,decltype(auto)
c++·c++40周年·lambda初始化捕获·decltype auto
不会c嘎嘎37 分钟前
【C++】深入理解多态:从用法到原理
开发语言·c++
REDcker40 分钟前
软件开发者需要关注CPU指令集差异吗?
linux·c++·操作系统·c·cpu·指令集·加密算法
不知所云,1 小时前
5. SDL3 库项目引入
c++·sdl3
C++ 老炮儿的技术栈1 小时前
用密码学安全随机数生成256位密钥
c语言·开发语言·c++·windows·安全·密码学·visual studio
nianniannnn2 小时前
Eigen 矩阵操作笔记
c++·笔记·线性代数·矩阵
adfass2 小时前
桌面挂件时钟/多功能时钟C++
开发语言·c++·算法
全栈视界师2 小时前
《机器人实践开发②:Foxglove 嵌入式移植 + CMake 集成》
c++·机器人·数据可视化
繁华似锦respect2 小时前
Linux-内核核心组成部分
linux·c++
不知所云,3 小时前
2.windows c/c++ 编译器安装, mingw和clang
c语言·c++·windows·mingw·clang·c编译器