当前位置: 首页 > article >正文

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


http://www.kler.cn/a/604828.html

相关文章:

  • web爬虫笔记:js逆向案例十一 某数cookie(补环境流程)
  • DeepSeek反作弊技术方案全解析:AI如何重构数字信任体系
  • 如何使用 Postman 网页版?
  • Excel新增的函数
  • Unity AzureKinect AvatarController 公开变量解释
  • -PHP 应用模版引用Smarty 渲染MVC 模型数据联动RCE 安全
  • 2025-03-24 学习记录--C/C++-PTA 习题7-7 字符串替换
  • conda环境下解决gitk乱码模糊
  • Flutter项目之table页面实现
  • linux/android 如何获取当前系统启动时长
  • 000-JMeter简介
  • docker ssh远程连接
  • Python+Pytorch掌纹训练识别
  • STM32八股【1】-----启动流程和startup文件理解
  • [新闻.AI]国产大模型新突破:阿里开源 Qwen2.5-VL-32B 与 DeepSeek 升级 V3 模型
  • Mamba 模型:深度学习序列建模的新突破​
  • 3. 轴指令(omron 机器自动化控制器)——>MC_CamIn
  • 架构设计之自定义延迟双删缓存注解(下)
  • 记录firefly的3566-sdk的下载及解压更新
  • 大模型知识补充四