红黑树原理以及插入、删除算法 附图例说明

1、概念spa

R-B Tree,全称是Red-Black Tree又称红黑树,它是一种特殊的二叉查找树,红黑树的每一个节点上都有存储位表示节点的颜色,能够是红或黑。3d

2、特性blog

一、每一个节点或者是红色,或者是黑色二叉树

二、根节点是黑色的方法

三、每一个叶子节点(NIL)是黑色的。注意:这里的叶子节点,是指为空的叶子节点im

四、若是一个节点是红色的,则它的子节点必须是黑色的d3

五、从任意一个节点到其叶子的全部路径中,所包含的黑节点数量是相同的数据

特性解析1:根据特性4可知,从每一个叶子节点到根节点的全部路径中不能有两个连续的红节点db

特性解析2:根据特性5可知,没有一条路径会比其它路径长出两倍,于是红黑树是接近平衡的二叉树img

3、应用

红黑树主要用于存储有序的数据,它的时间复杂度是O(logn),很是高效

4、基本操做——插入

一、简介

红黑树的基本操做是添加和删除,在对红黑树进行添加和删除以后,都会用到旋转方法。为何要用旋转方法呢?由于添加或删除红黑树的节点以后,红黑树就发生了变化,可能就不知足红黑树的5条性质了,也就不是一颗红黑树了。而经过旋转能够使这棵树从新成为红黑树,即旋转的目的就是为了保证红黑树的特性

左旋:对节点x进行左旋,意味着将“x的右孩子变成x的父亲”,而将“x原先的右孩子的左孩子变成x的右孩子”。即左旋中的“左”是指将别旋转的节点变成一个左节点

右旋:对节点x进行右旋,意味着将“x的左孩子变成x的父亲,而将”x原先的左孩子的右孩子变成x的右孩子“。即右旋中的”右“是指将被旋转的节点变成一个右节点

二、插入规则

新插入的节点都为红色

三、红黑树插入的4种情形

(1)新节点位于根节点,其没有父节点时,处理思路:将该节点直接设为黑色便可

(2)新节点的父节点已然是黑色时,处理思路:不用动,这已然是一颗红黑树

(3)父节点和叔节点都是红色时,处理思路:a.将父节点和叔节点设为黑色;b.将祖父节点设为红色;c.将祖父节点设为当前节点,并继续对新当前节点进行操做

(4)父节点是红色,叔节点是黑色时,又分以下四种状况:

  • 当前节点是父亲的左孩子,父亲是祖父的左孩子(Left-Left),处理思路:a.将祖父节点右旋;b.交换父节点和祖父节点的颜色
  • 当前节点是父亲的右孩子,父亲是祖父的左孩子(Right-Left),处理思路:a.将父节点左旋,并将父节点做为当前节点; b.而后再使用Left Left情形
  • 当前节点是父亲的右孩子,父亲是祖父的右孩子(Right-Right),处理思路:a.将祖父节点左旋;b.交换父节点和祖父节点的颜色
  • 当前节点是父亲的左孩子,父亲是祖父的右孩子(Left-Right),处理思路:a.将父节点右旋,并将父节点做为当前节点; b.而后再使用Right Right情形

四、插入图例

经过插入12   1   9   2   0   11   7   19   4   15   18   5   14   13   10   16   6   3   8   17完成上述全部情形的展现。

(1)插入12

说明:插入的节点如果根节点,则直接将其设置为黑色

(2)插入1

说明:插入的节点若不是根节点,则将其设置为红色

(3)插入9

(4)插入2

(5)插入0

(6)插入11

(7)插入7

(8)插入19

(9)插入4

(10)插入15

(11)插入18

(12)插入5

(13)插入14

(14)插入13

(15)插入10

(16)插入16

(17)插入6

(18)插入3

(19)插入8

(20)插入17

插入的过程讲解完毕。

5、基本操做——删除

一、红黑树删除的情形

1、从树中删除节点X以寻找后继节点的方式进行删除

状况①:若是X没有孩子,且若是X是红色,直接删除X;若是X是黑色,则X为当前节点进行旋转调色,最后删X

状况②:若是X只有一个孩子C,交换XC的数值,再对新X进行删除。根据红黑树特性,此时X不可能为红色,由于红色节点要么没有孩子,要么有两个黑孩子。此时以新X当前节点进行状况①的判断

状况③:若是X有两个孩子,则从后继中找到最小节点D,交换XD的数值,再对新X进行删除。此时以新X为当前节点进行状况①或②的判断

2、旋转调色N=旋转调色的当前节点[等于状况①中的X]P=N的父亲,W=N的兄弟,Nf=N的远侄子,Nn=N的近侄子

状况1N是根或者N是红色,则:直接将N设为黑色

状况2N不是根且N是黑色,且W为红色,则:W设为黑色,P设为红色,对P进行旋转(NP左子时进行左旋,N为P的右子时进行右旋),将状况转化为状况12345

状况3N不是根且N是黑色,且W为黑色,且W的左右子均为黑色,则:W设为红色,将P设为当前节点进行旋转调色,将状况转化为状况12345

状况4N不是根且N是黑色,且W为黑色,且Nf为黑色,Nn为红色,则:交换WNn的颜色,并对W进行旋转(NP的左子进行右旋,NP的右子进行左旋),旋转后N的新兄弟W有一个红色WR,则转换为状况5

状况5N不是根且N是黑色,且W为黑色,且Nf为红色,Nn为黑色,则:W设为P的颜色,PNf设为黑色,并对P进行旋转(NP的左子进行左旋,NP的右子进行右旋)N设为根

二、插入图例

经过删除12   1   9   2   0   11   7   19   4   15   18   5   14   13   10   16   6   3   8   17完成上述全部情形的展现。

(1)删除12

(2)删除1

(3)删除9

(4)删除2

(5)删除0

(6)删除11

(7)删除7

(8)删除19

(9)删除4

(10)删除15

(11)删除18

(12)删除5

(13)删除14

(14)删除13

(15)删除10

(16)删除16

(17)删除6

(18)删除3

(19)删除8

(20)删除20

删除完毕!

相关文章
相关标签/搜索