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

相关推荐
weixin_423533991 小时前
c++类的继承学习-去中心化交易所(DEX)的“流动性池初始化与交易指令”设计
c++·学习·去中心化
unicrom_深圳市由你创科技5 小时前
数据库用SQLite还是SQL Server?工业数据存储选哪个?
c++
郝学胜_神的一滴5 小时前
CMake 037:宏传递流转机制与C++编译特性跨平台适配指南
c++·cmake
apocelipes2 天前
常用编程语言和库的正则表达式性能对比
c语言·c++·python·性能优化·golang·开发工具和环境
郝学胜_神的一滴3 天前
CMake 034:生成器表达式:解耦构建时序、精简分支逻辑的终极利器
c++·cmake
见过夏天4 天前
C++ 基础入门完全指南
c++
用户805533698035 天前
不止三件套:QObject 属性系统全关键字与运行时反射!
c++·qt
BadBadBad__AK6 天前
线段树维护区间 k 次方和
c++·数学·算法·stl
卷无止境6 天前
Eigen 库如何借助 OpenMP 加速计算
c++·后端
卷无止境6 天前
OpenMPI、MPICH 与 OpenMP:关系、核心概念与架构全解
c++·后端