红黑树操作

2019-12-19  本文已影响0人  斜不靠谱

红黑树定义和性质

红黑树是一种含有红黑结点并能自平衡的二叉查找树。它必须满足下面性质:

红黑树插入节点处理

image.png

其中节点名称定义如下


image.png image.png image.png

红黑树删除节点处理

红黑树节点删除分为两步

二叉树删除结点找替代结点有3种情情景:

通过上面讨论,得知红黑树删除节点只需要关注情景1,2,其中2和1.1比较简单,后面重点关注1.2 删除黑色的叶子节点
因为一旦该节点被拿掉,红黑树中通过该节点的路径黑色节点数量将会减1,而且无法像情形2那样将子节点涂黑来达到平衡。此时只能自底向上进行平衡操作。

情景1.2删除节点后再平衡

本文余下内容均指的是删除黑色的叶子节点后引发的一系列平衡操作。比如P->D->N,删除D(黑色)后,N接至父节点:P->N。
因为删除了一个黑色节点(N的父节点D),经过N的路径的黑色数量减1,即h(P->N->叶子) 比 h(P->S->叶子) 少1。

平衡的方式有:
(1)h(P->N->叶子)不变,h(P->S->叶子)减1,此时已经子平衡;然而h(GP->P->叶子)还是会比h(GP -> U ->叶子)少1。此时需要将P当作新的N,向上递归处理;

(2)h(P->N->叶子)加1,h(P->S->叶子)不变,也就是恢复了原来的状态,此时已经平衡,因为h(GP->P->叶子)=h(GP -> U ->叶子)。

删除平衡情形,主要根据 [兄节点的位置/颜色]、[兄的子节点的颜色]、[父节点颜色] 进行分类
7779607-e1716801d002f2b1.png

参考

30张图带你彻底理解红黑树
彻底理解红黑树(三)之 删除

上一篇 下一篇

猜你喜欢

热点阅读