红黑树(简易版)

一、一句话

红黑树 ≈ 近似平衡的二叉查找树,保证查找 O(log n)


二、5 条性质(背前 4 条即可)

  1. 节点是 红 / 黑
  2. 根是
  3. 叶子(NIL)是
  4. 红节点的孩子必须是黑(不能连续红)
  5. 任意节点到叶子的 黑高相同(保证平衡)

三、vs AVL(面试必问)

对比 红黑树 AVL
平衡 弱平衡(黑高一致) 严格平衡
插入/删除 更快(旋转少)
查询 稍慢 更快
应用 TreeMap、HashMap 早期数据库

插入删除多 → 红黑树;查询多 → AVL


四、旋转(理解就行)

  • 左旋:右子变父
  • 右旋:左子变父

五、插入(只记结论)

  1. 新节点默认 红色
  2. 父节点是黑 → 结束
  3. 父节点是红 → 看叔叔
    • 叔叔红 → 变色 + 上推
    • 叔叔黑 → 旋转 + 变色

六、时间复杂度

操作 时间
查找 O(log n)
插入 O(log n)
删除 O(log n)

七、工程应用

  • Java TreeMap / TreeSet
  • C++ std::map
  • Linux 调度器

八、要不要手写?

面试 刷题 工作
❌ 不考 ❌ 不写 ❌ 不用写

只考理论,不考手写。


相关推荐
NQBJT1 小时前
万字拆解 NeckFix:AI 脖子前倾检测的算法原理与工程实现
人工智能·算法
jaychouchannel1 小时前
Python 常用排序算法详解
算法
数智工坊1 小时前
【Inner Monologue论文阅读】: 首次将大语言模型嵌入机器人控制闭环,实现自我反思和动态行为调整
论文阅读·人工智能·算法·语言模型·机器人·无人机
为何创造硅基生物2 小时前
C 语言 typedef 结构体私有化
c语言·开发语言·算法
yzx9910132 小时前
递归算法入门:像俄罗斯套娃一样思考
人工智能·算法
心中有国也有家2 小时前
从零上手 CANN 学习中心:像逛技术便利店一样学昇腾
学习·算法·开源
oo哦哦2 小时前
搜索矩阵系统的最短路密码:用Dijkstra算法和网络流理论,解释为什么你做了1000个关键词,流量还不如别人30个
网络·算法·矩阵
Matlab程序猿小助手2 小时前
【MATLAB源码-第319期】基于matlab的帝王蝶优化算法(MBO)无人机三维路径规划,输出做短路径图和适应度曲线.
开发语言·算法·matlab
图码3 小时前
二分查找进阶:如何在有序数组中快速找到Upper Bound?
数据结构·算法·面试·分类·柔性数组