红黑树(简易版)

一、一句话

红黑树 ≈ 近似平衡的二叉查找树,保证查找 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 调度器

八、要不要手写?

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

只考理论,不考手写。


相关推荐
复杂网络1 小时前
AI 不睡觉,但它比你更会做实验
算法
贵慜_Derek1 小时前
MAI-04|干净数据在工程上意味着什么:MAI 预训练数据治理
人工智能·算法·llm
vibecoding日记19 小时前
双非如何快速入职字节等大厂大模型?真实案例分析:推理优化和投机解码
算法·求职·大模型工程师
yszaygr213821 小时前
Verilog参数化游程编码RLE模块
算法
望易1 天前
刚设计的大模型架构-双域耦合认知框架
算法·架构
复杂网络1 天前
多个 Claude Code 与多个 Codex 协同工作:设计与实现方案
算法
HjhIron2 天前
面试常客:字符串算法从入门到进阶
算法·面试
吴佳浩2 天前
DeepSeek DSpark:Confidence-Scheduled Speculative Decoding 技术解析
人工智能·算法·deepseek