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

相关推荐
BS_Li17 分钟前
用哈希表封装unordered_set和unordered_map
数据结构·c++·哈希算法·散列表
waves浪游1 小时前
C++多态
开发语言·c++
aramae1 小时前
快速排序的深入优化探讨
c语言·开发语言·c++·算法·排序算法
qq_437896432 小时前
unsigned 是等于 unsigned int
开发语言·c++·算法·c
Yupureki4 小时前
从零开始的C++学习生活 2:类和对象(上)
c语言·开发语言·c++·学习·visual studio
字节高级特工5 小时前
网络协议分层与Socket编程详解
linux·服务器·开发语言·网络·c++·人工智能·php
FS_tar5 小时前
高斯消元矩阵
c++·算法·矩阵
闻缺陷则喜何志丹6 小时前
【贪心之临项交换】P8732 [蓝桥杯 2020 国 ABC]|普及
c++·算法·蓝桥杯·贪心·洛谷
charlie1145141916 小时前
理解C++20的革命特性——协程支持1
c++·学习·c++20·协程·语言特性·调度·现代c++
郝学胜-神的一滴6 小时前
Effective STL 第1条:慎重选择容器类型
开发语言·c++·程序人生·软件工程