平衡二叉搜索树(AVL)和红黑树(RB-Tree)

2018-07-25  本文已影响19人  XDgbh

二、红黑树——一种常被使用的平衡二叉搜索树

1、四大性质
2、由四大性质引出的要插入的节点性质讨论
3、红黑颜色的本质是bool值,红色是false0,黑色是true1
image.png
4、红黑树增加一个特殊的header节点

初始时,herder的左右子节点都指向本身,插入节点后;左子节点作为begin()指向的是(most)left最左边也就是最小值;右子节点作为end()指向的是(most)right最右边也就是最大值。


image.png
5、迭代器++和--的特殊操作

6、AVL-tree平衡二叉树的平衡破坏情况

每个结点有一个元素是平衡因子Balance Factor,BF=该结点左子树高度-右子树高度,当BF的绝对值大于1时说明平衡被破坏。距离插入结点最近的BF绝对值大于1的结点,就作为要开始接受调整的结点,以它为根的子树叫做最小不平衡子树


AVL-tree平衡调整

6.1、红黑树新插入节点保持平衡的变色和旋转条件

不管是左左(父节点是祖父节点的左子节点,X节点又是父节点的左子节点,后面同理)、左右、右左、右右,全部都只需要变色处理,而不需要旋转。
为了满足性质3【父子节点不能双红】则需要将父节点和伯父节点都转为黑色。此时这两路径黑色节点数+1,为了满足性质4【各节点所有路径黑色节点数相同】则需要将祖父节点变为红色。然后还需要继续向上检查是否有父子双红的颜色冲突,有的话就还需要继续向上变色处理,可能直到根节点才结束。

1、左左,单右旋转,附带变色。
2、右右,单左旋转,附带变色。
3、左右,先单左再单右的双旋转,附带变色。
4、右左,先单右再单左的双旋转,附带变色。

7、关于单旋转,双旋转的细节

单左旋。对应右右,或者左右的第一次旋转


单左旋

单右旋。对应左左,或者右左的第一次旋转


单右旋

8、平衡调整函数,调整颜色、调整位置(调用左旋转和右旋转)

调整平衡树函数

一个图示实例:将序列10、7、8、15、5、6、11、13、12依次插入红黑树的调整过程》》》》》


上一篇 下一篇

猜你喜欢

热点阅读