1. 理解前的知识储备
-
二叉排序树
通常二叉排序树呈现的特点是左子树元素值<根节点值<右子树元素值
即右子树元素全部大于左子树元素及根节点;左子树元素全部小于右子树元素及根节点
-
平衡二叉树
左右子树高度差小于等于
1
的二叉排序树 -
最小不平衡树
一棵二叉排序树中左右子树高度差大于
1
的最小单位树。平衡二叉树插入新节点后只可能出现一棵最小不平衡树,经过平衡调整后的平衡二叉树不存在最小不平衡树以下是两个例子,红笔圈起来的部分即最小不平衡树
2.LL旋转
当新节点添加在最小不平衡树根节点的左孩子的左子树且造成不平衡时使用此旋转
操作
-
确定最小不平衡树在整棵树中的位置
-
定位到此树
根节点R
的左节点P
,目标是让P
成为最终的根节点 -
将
左节点P
进行右旋转【即让P
去到根节点R
的位置,根节点R
下沉到右节点】,此操作不会破坏二叉排序树的结构 -
若
左节点P
有右子树,则一并放到旋转后的根节点R
的左边这里用到了二叉排序树右子树大于左子树的性质,因为原先
P
的右子树属于根节点R
的左子树,所以P
的右子树中所有节点值必定小于根节点R
以及根节点R
的右子树。经过旋转后,
根节点R
成为了P
的右子树,而原先P
的右子树必然是比P
大且小于根节点R
的,所以原先P
的右子树放在P
的右边,根节点R
的左边
3.RR旋转
当新节点添加在最小不平衡树根节点的右孩子的右子树且造成不平衡时使用此旋转
操作
-
确定最小不平衡树在整棵树中的位置
-
定位到此树
根节点R
的右节点P
,目标是让P
成为最终的根节点 -
将
右节点P
进行左旋转【即让P
去到根节点R
的位置,根节点R
下沉到左节点】,此操作不会破坏二叉排序树的结构 -
若
右节点P
有左子树,则一并放到旋转后的根节点R
的右边这里用到了二叉排序树左子树小于右子树的性质,因为原先
P
的左子树属于根节点R
的右子树,所以P
的左子树中所有节点值必定大于根节点R
以及根节点R
的左子树。经过旋转后,
根节点R
成为了P
的左子树,而原先P
的左子树必然是比P
小且大于根节点R
的,所以原先P
的左子树放在P
的左边,根节点R
的右边
4.LR旋转
当新节点添加在最小不平衡树根节点的左孩子的右子树且造成不平衡时使用此旋转
操作
-
确定最小不平衡树在整棵树中的位置
-
定位到此树
根节点R
的左节点L
的右孩子P
,目标是让P
成为最终的根节点 -
先将
P
左旋转到L
的位置,此时将P
记作Q
-
再将
Q
右旋转到R
的位置 -
同理,若
Q
有右子树,则将此右子树一并放入到旋转后根节点R
的左边原理同LL与RR旋转,可仔细体会上述解释过程
5. RL旋转
当新节点添加在最小不平衡树根节点的右孩子的左子树且造成不平衡时使用此旋转
操作
-
确定最小不平衡树在整棵树中的位置
-
定位到此树
根节点R
的右节点L
的左孩子P
,目标是让P
成为最终的根节点 -
先将
P
右旋转到L
的位置,此时将P
记作Q
-
再将
Q
左旋转到R
的位置 -
同理,若
Q
有左子树,则将此左子树一并放入到旋转后根节点R
的右边原理同LL与RR旋转,可仔细体会上述解释过程
6. 总结
平衡二叉树的旋转不需要死记,千万不要被通篇的左右子树给弄迷糊了,建议可以画图进行步骤阅读,结合二叉排序树的性质可以更好的进行理解,若这篇文章对你有所帮助的话,不放给个免费的赞支持一下。