漫画:什么是红黑树?(整合版)(上)

简介: 二叉查找树(BST)具备什么特性呢?1.左子树上所有结点的值均小于或等于它的根结点的值。2.右子树上所有结点的值均大于或等于它的根结点的值。3.左、右子树也分别为二叉排序树。

640.png640.png


 

—————  第二天  —————


640.png640.png640.png640.png640.png640.png640.png

 

 

————————————

640.png640.png640.png640.png

 

 

二叉查找树(BST)具备什么特性呢?

 

1.子树上所有结点的值均小于或等于它的根结点的值。

2.子树上所有结点的值均大于或等于它的根结点的值。

3.左、右子树也分别为二叉排序树。

 

下图中这棵树,就是一颗典型的二叉查找树:

 

 

640.png640.png

 

 

1.查看根结点9

 

640.png

 

 

2.根据二叉查找树左子树小、右子树大的特性,10 > 9,因此值为10的结点只可能在根结点的右子树当中,我们查看右孩子结点13

 

 640.png

 

3.由于10 < 13,因此查看左孩子11

 640.png

 

 

4.由于10 < 11,因此查看左孩子10,发现10正是要查找的结点:

 

640.png

640.png640.png640.png640.png640.png640.png640.png

 

假设初始的二叉查找树只有三个结点,根结点值为9,左孩子值为8,右孩子值为12

 

 640.png

接下来我们依次插入如下五个结点:7,6,5,4,3。依照二叉查找树的特性,结果会变成什么样呢?

 

 

640.png

640.png640.png640.png640.png

 

 

1.结点是红色或黑色。

2.根结点是黑色。

3.每个叶子结点都是黑色的空结点(NIL结点)。

4 每个红色结点的两个子结点都是黑色。(从每个叶子到根的所有路径上不能有两个连续的红色结点)

5.从任一结点到其每个叶子的所有路径都包含相同数目的黑色结点。

 

下图中这棵树,就是一颗典型的红黑树:

 

640.png640.png640.png640.png

 

什么情况下会破坏红黑树的规则,什么情况下不会破坏规则呢?我们举两个简单的例子:

 

1.向原红黑树插入值为14的新结点:

 

 640.png

 

由于父结点15是黑色结点,因此这种情况并不会破坏红黑树的规则,无需做任何调整。

 

 

2.向原红黑树插入值为21的新结点:

 

 

640.png

 

由于父结点22是红色结点,因此这种情况打破了红黑树的规则4(每个红色结点的两个子结点都是黑色),必须进行调整,使之重新符合红黑树的规则。

640.png640.png

 

变色:

 

为了重新符合红黑树的规则,尝试把红色结点变为黑色,或者把黑色结点变为红色。

 

下图所表示的是红黑树的一部分(子树),新插入的结点Y是红色结点,它的父亲结点X也是红色的,不符合规则4,因此我们可以把结点X从红色变成黑色:

 640.png

 

但是,仅仅把一个结点变色,会导致相关路径凭空多出一个黑色结点,这样就打破了规则5。因此,我们需要对其他结点做进一步的调整,后文会详细说明。

 

 

左旋转:

 

逆时针旋转红黑树的两个结点,使得父结点被自己的右孩子取代,而自己成为自己的左孩子。说起来很怪异,大家看下图:

 

640.png

 

图中,身为右孩子的Y取代了X的位置,而X变成了自己的左孩子。此为左旋转。

 

 

右旋转:

 

顺时针旋转红黑树的两个结点,使得父结点被自己的左孩子取代,而自己成为自己的右孩子。大家看下图:

 

640.png

 

图中,身为左孩子的Y取代了X的位置,而X变成了自己的右孩子。此为右旋转。

640.png640.png640.png

 

局面1新结点(A)位于树根,没有父结点。

 

640.png

(空心三角形代表结点下面的子树)

 

这种局面,直接让新结点变色为黑色,规则2得到满足。同时,黑色的根结点使得每条路径上的黑色结点数目都增加了1,所以并没有打破规则5

 

640.png

 

局面2新结点(B)的父结点是黑色。

 

这种局面,新插入的红色结点B并没有打破红黑树的规则,所以不需要做任何调整。

 

640.png

 

局面3新结点(D)的父结点和叔叔结点都是红色。

 640.png

这种局面,两个红色结点BD连续,违反了规则4。因此我们先让结点B变为黑色:

 

640.png

这样一来,结点B所在路径凭空多了一个黑色结点,打破了规则5。因此我们让结点A变为红色:

 

 640.png

这时候,结点AC又成为了连续的红色结点,我们再让结点C变为黑色:

 

640.png

 

经过上面的调整,这一局部重新符合了红黑树的规则。

 

 

局面4新结点(D)的父结点是红色,叔叔结点是黑色或者没有叔叔,且新结点是父结点的右孩子,父结点(B)是祖父结点的左孩子。

 640.png

我们以结点B为轴,做一次左旋转,使得新结点D成为父结点,原来的父结点B成为D的左孩子:

 

640.png

这样一来,进入了局面5

 

局面5新结点(D)的父结点是红色,叔叔结点是黑色或者没有叔叔,且新结点是父结点的左孩子,父结点(B)是祖父结点的左孩子。

 

640.png

我们以结点A为轴,做一次右旋转,使得结点B成为祖父结点,结点A成为结点B的右孩子:

 640.png

接下来,我们让结点B变为黑色,结点A变为红色:

 

640.png

经过上面的调整,这一局部重新符合了红黑树的规则。

 

 

以上就是红黑树插入操作所涉及的5种局面。

 

或许有人会问,如果局面4和局面5当中的父结点B是祖父结点A的右孩子该怎么办呢?

 

很简单,如果局面4中的父结点B是右孩子,则成为了局面5的镜像,原本的右旋操作改为左旋;如果局面5中的父结点B是右孩子,则成为了局面4的镜像,原本的左旋操作改为右旋。

 

640.png640.png

 

 

给定下面这颗红黑树,新插入的结点是21

 

 640.png

显然,新结点21和它的父结点22是连续的红色结点,违背了规则4,我们应该如何调整呢?

 

让我们回顾一下刚才讲的5种局面,当前的情况符合局面3

“新结点的父结点和叔叔结点都是红色。”

 

于是我们经过三次变色,22变为黑色,25变为红色,27变为黑色:

 640.png

 

经过上面的调整,以结点25为根的子树符合了红黑树规则,但结点25和结点17成为了连续的红色结点,违背规则4

 

于是,我们把结点25看做一个新结点,正好符合局面5的镜像:

“新结点的父结点是红色,叔叔结点是黑色或者没有叔叔,且新结点是父结点的右孩子,父结点是祖父结点的右孩子”

 

于是我们以根结点13为轴进行左旋转,使得结点17成为了新的根结点:

 

640.png

 

接下来,让结点17变为黑色,结点13变为红色:

 

640.png

 


相关文章
|
存储 机器学习/深度学习 算法
数据结构 | 有关树和二叉树的详解【内附考点精析】
树和二叉树的基本概念和性质,内附精致讲解图和推理过程
243 0
数据结构 | 有关树和二叉树的详解【内附考点精析】
|
算法 开发者
数据结构和算法-约瑟夫问题解决(1)|学习笔记
快速学习数据结构和算法-约瑟夫问题解决(1)
103 0
数据结构和算法-约瑟夫问题解决(1)|学习笔记
|
算法 开发者
数据结构和算法-约瑟夫问题解决(2)|学习笔记
快速学习数据结构和算法-约瑟夫问题解决(2)
数据结构和算法-约瑟夫问题解决(2)|学习笔记
|
存储 算法 安全
数据结构与算法—一文多图搞懂双链表
前面讲过线性表中顺序表和链表的实现和性质。但是在数据结构与算法中,双向链表无论在考察还是运用中都占有很大的比例,笔者旨在通过本文与读者一起学习分享双链表相关知识。
151 0
数据结构与算法—一文多图搞懂双链表
|
存储 NoSQL 关系型数据库
漫画:什么是跳跃表?
如果是没有商品名称的全量查询怎么办?总不可能把数据库里的所有记录全查出来吧,而且还要支持不同字段的排序。 所以,只能提前在内存中存储有序的全量商品集合,每一种排序方式都保存成独立的集合,每次请求的时候按照请求的排序种类,返回对应的集合。
146 1
漫画:什么是跳跃表?
|
存储 Java
【Java实现链表操作】 万字肝爆 !链表的图文解析(包含链表OJ练习解析)
(温馨提示:)本文字数比较多需要慢慢观看,建议收藏此文有时间慢慢观看,看完此文你会学习到什么是链表,什么是双向链表,单链表的增删查改的基本代码思路和在线OJ题的基本代码思路。
339 0
|
搜索推荐 算法 Shell
【漫画】七种最常见的排序算法(动图版)(中)
【漫画】七种最常见的排序算法(动图版)
170 1
|
存储
还不知道层序遍历有多强?带你一口气打穿十道题(动图理解)(中)
还不知道层序遍历有多强?带你一口气打穿十道题(动图理解)
121 0
还不知道层序遍历有多强?带你一口气打穿十道题(动图理解)(中)
还不知道层序遍历有多强?带你一口气打穿十道题(动图理解)(上)
众所周知二叉树的遍历一般是前中后序遍历,但其实还有一种层序遍历。它是按照一层一层的顺序去遍历二叉树
186 0
还不知道层序遍历有多强?带你一口气打穿十道题(动图理解)(上)
漫画:什么是红黑树?(整合版)(下)
二叉查找树(BST)具备什么特性呢? 1.左子树上所有结点的值均小于或等于它的根结点的值。 2.右子树上所有结点的值均大于或等于它的根结点的值。 3.左、右子树也分别为二叉排序树。
136 0
漫画:什么是红黑树?(整合版)(下)