【数据结构】红黑树

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了【数据结构】红黑树相关的知识,希望对你有一定的参考价值。

参考技术A

      红黑树是一个要求不那么严格的平衡二叉树搜索树(平衡二叉搜索树/AVL树=平衡二叉树+二叉搜索树)
平衡二叉树要求左右子树高度差值<=1,红黑树放宽了这个要求,只要求任意路径的长度只差不会超过2倍即可。更准确的说是任意路径上的的黑色节点数相同即可

红黑树可用于数据查找,因为其“相对”平衡,所以其查找效率略低于平衡二叉搜索树,但是也非常高效。

      平衡二叉树的要求过于严格(左右子树高度差值<=1),导致几乎每一次插入/删除节点都会破坏平衡二叉树的结构,需要将其重新调整为平衡二叉树。
      显然,如果在那种插入、删除很频繁的场景中,平衡树需要频繁着进行调整,这会使平衡树的性能大打折扣。而红黑树因为不是严格的平衡,所以可以避免这个问题,同时红黑树又是一个“相对”平衡的二叉搜索树,所以其查找性能也很好。

1、每个节点都有颜色(红或黑)
2、根节点是黑色的
3、叶节点时黑色的(注意:叶节点是空节点,有值的节点都不是叶结点)
4、没有两个相邻的红色节点(或者说红色节点的子节点一定是黑色节点)
5、从根节点到叶结点的每条路径包含的黑色节点相同(又叫:黑节点平衡)

与二叉搜索树查找数据的过程一致

(若插入数据后破坏了红黑树的性质,则需要对红黑树进行“再平衡”,使其满足红黑树的性质。并且新插入的节点最多只会破坏5条性质中的1条)
插入数据分为了3种情况
1、插入的节点,其没有父节点
2、插入的节点,其父节点是黑色节点
3、插入的节点,其父节点是红色节点

第一种情况 :插入的节点没有父节点,说明插入的节点是根节点,此时直接将节点的颜色改为黑色即可

第二种情况 :插入的节点,其父节点是黑色节点,此时不需要采取措施。新插入的节点并没有破坏红黑树的性质

第三种情况 :插入的节点,其父节点是红色节点。如图

可以看到21和22同为红色,破坏了“ 没有两个相邻的红色节点 ”性质,需要进行 再平衡 操作。

分为以下情况(共同前提:插入节点的父节点是红色):
1、插入节点的父节点的兄弟节点(即插入节点的叔叔节点,就是上图中的27节点)是红色
2、插入节点的父节点的兄弟节点是黑色

第一步:将其父节点颜色变为黑色
因为其父节点颜色变成了黑色,所以包含其父节点的这条路径多了一个黑色节点。破坏了“ 从根节点到叶结点的每条路径包含的黑色节点相同 ”性质,如上面的13,17,25,22(变成了黑色),21路径

第二步:看其叔叔的颜色:

第一种情况 :其叔叔节点为红色(其父节点为红色的前提下)
步骤:
1、把叔叔节点变成黑色
2、把其祖父节点(父节点的父节点)变成红色。若其祖父节点为根节点,则不变色
3、把祖父节点当做新插入的节点,重复1,2,3步骤直到其祖父节点为根节点

第二种情况 :其叔叔节点为黑色(其父节点为红色的前提下)
这种情况下又分为两种情况:
1、新插入的子节点是父节点的左子节点
2、新插入的子节点是父节点的右子节点

第一种情况 :新插入的子节点是父节点的左子节点(其叔叔节点为黑色,并且其父节点为红色的前提下)
步骤:(先变色,在右旋)

1、将其父节点变为黑色
2、将其祖父节点变为红色(其父节点是红色,则其祖父节点必为黑色)
3、以其父节点为支点,进行右旋操作(如何右旋?百度上有很形象的动画演示)

第二种情况 :新插入的子节点是父节点的右子节点(其叔叔节点为黑色,并且其父节点为红色的前提下)
步骤:( 先左旋将其变为情况一,在按情况一的操作来进行

以新插入的节点为支点,进行左旋操作, 变为情况一,此时将插入节点的父节点(上图的P节点)当做新插入的节点来进行情况一步骤下的:变色,右旋操作

下面我们开始讨论删除操作(下面的叶子节点都是指非NULL的叶子节点):

A. 删除的是叶子节点且该叶子节点是红色的 ---> 无需修复,因为它不会破坏红黑树的5个特性

B. 删除的是叶子节点且该叶子节点是黑色的 ---> 很明显会破坏特性5,需要修复。

C. 删除的节点(为了便于叙述我们将其称为P)下面有一个子节点 S,对于这种情况我们通过 将P和S的值交换的方式,巧妙的将删除P变为删除S,S是叶子节点,这样C这种情况就会转 换为A, B这两种情况:

C1: P为黑色,S为红色 ---> 对应 A 这种情况

C2: P为黑色或红色,S为黑色 --- > 对应 B 这种情况

**D. **删除的节点有两个子节点,对于这种情况,我们通过将P和它的后继节点N的值交换的方 式,将删除节点P转换为删除后继节点N,而后继节点只可能是以下两种情况:

D1: N是叶子节点 --- > 对应情况 A 或 B

D2: N有一个子节点 ---- > 对应情况 C

所以通过上面的分析我们发现,红黑树节点删除后的修复操作都可以转换为 A 或 B这两种情况,而A不需要修复,所以我们只需要研究B这种情况如何修复就行了。

下面我们讨论如何修复B中情况:(若没有兄弟节点,则其兄弟节点是null节点,根据红黑树的性质,null节点为黑色)

以上是关于【数据结构】红黑树的主要内容,如果未能解决你的问题,请参考以下文章

数据结构-红黑树

数据结构 - 红黑树(Red Black Tree)删除详解与实现(Java)

红黑树数据结构剖析

红黑树数据结构剖析

数据结构 - 学习笔记 - 红黑树前传——234树

【数据结构】红黑树