数据结构-红黑树

一、定义

红黑树是一种自平衡的二叉查找树,通过给结点标记红/黑颜色,并遵循特定规则,保证树的高度始终维持在 O(\log n),从而确保增删查改的时间复杂度稳定为 O(\log n)。

• 基础特性:满足二叉查找树的核心规则------左子树所有结点值 < 根结点值,右子树所有结点值 > 根结点值,左右子树也为二叉查找树。

二、红黑树的 5 条核心性质

  1. 每个结点要么是红色,要么是黑色。

  2. 根结点必须是黑色。

  3. 所有叶子结点(NIL 结点,空结点)都是黑色。

  4. 如果一个结点是红色,那么它的两个子结点必须都是黑色(不存在连续的红色结点)。

  5. 从任意一个结点到其所有后代叶子结点的每条路径上,包含相同数量的黑色结点(黑高一致)。

三、关键概念

  1. 黑高:从某结点到其叶子结点的路径上,黑色结点的数量(不包含该结点自身),叶子结点的黑高为 0。

  2. NIL 结点:红黑树的叶子结点并非空,而是用一个虚拟的黑色 NIL 结点表示,用于简化边界条件处理。

四、核心操作及失衡调整

红黑树插入、删除结点后可能破坏 5 条性质,需通过变色和旋转两种操作恢复平衡。

  1. 两种旋转操作(保证二叉查找树性质不变)

• 左旋:以某个结点为支点,将其右子树提升为新根,原根变为新根的左子树,新根的原左子树变为原根的右子树。

• 右旋:以某个结点为支点,将其左子树提升为新根,原根变为新根的右子树,新根的原右子树变为原根的左子树。

  1. 插入操作

• 新插入的结点默认标记为红色(减少对黑高的影响,降低调整复杂度)。

• 插入后根据叔父结点的颜色分情况处理:

◦ 叔父结点为红色:父结点、叔父结点变色为黑,祖父结点变色为红,再以祖父结点为当前结点继续向上调整。

◦ 叔父结点为黑色:根据结点位置(左左、左右、右右、右左),结合旋转 + 变色完成调整。

  1. 删除操作

• 优先删除度为 0 或 1 的结点,若为度为 2 的结点,用其前驱/后继结点值替换自身,再删除前驱/后继结点。

• 删除后根据兄弟结点的颜色及兄弟子结点的颜色分情况调整,核心是保证路径黑高不变。

五、红黑树 vs 平衡二叉树(AVL 树)

• 平衡标准:红黑树是近似平衡(黑高一致),AVL 树是严格平衡(左右子树高度差绝对值 ≤ 1)。

• 调整频率:红黑树插入、删除的调整频率更低,适合频繁增删的场景;AVL 树查询效率略高,适合频繁查询的场景。

• 应用场景:红黑树常用于 Java TreeMap、C++ STL map/set;AVL 树常用于数据库索引等对查询性能要求极高的场景。

相关推荐
CSharp精选营13 小时前
关系型 vs 非关系型:从原理到选型,一文搞定数据库核心分类
数据结构·nosql·关系型数据库·非关系型数据库·技术选型
RainCity21 小时前
Java Swing 自定义组件库分享(十二)
java·笔记·后端
刘马想放假4 天前
Modbus 全栈技术解析:TCP、RTU、ASCII、RTU over TCP
数据结构·网络协议
北域码匠5 天前
冒泡排序太慢?鸡尾酒排序双向优化,原生 C# 零第三方库完整代码
数据结构·排序算法·泛型·c# 算法·鸡尾酒排序·原生 c# 开发·冒泡排序优化·嵌入式算法
LinXunFeng8 天前
Obsidian - 使用 Share Note 分享笔记并自部署
前端·笔记·github
Darling噜啦啦12 天前
列表转树算法深度解析:从 Map 到 Reduce 的两种实现,面试高频考点
数据结构·算法·面试
小小工匠13 天前
Redis - 事务机制:能实现 ACID 属性吗
数据结构·redis·性能优化·并发·持久化
玖玥拾13 天前
C/C++ 数据结构(七)栈、容器适配器
c语言·数据结构·c++··容器适配器
闪闪发亮的小星星13 天前
高斯光以及高斯光公式解释
笔记
cqbzcsq13 天前
CellFlow虚拟细胞论文阅读
论文阅读·人工智能·笔记·学习·生物信息