从零开始学数据结构系列之第三章《平衡二叉树的旋转类型图文详解》


简单回顾

2 种「旋转」方式:

  1. 左旋
    • 旧根节点为新根节点的左子树
    • 新根节点的左子树(如果存在)为旧根节点的右子树
  2. 右旋:
    • 旧根节点为新根节点的右子树
    • 新根节点的右子树(如果存在)为旧根节点的左子树

4 种「旋转」纠正类型

  1. LL 型:插入左孩子的左子树,右旋
  2. RR 型:插入右孩子的右子树,左旋
  3. LR 型:插入左孩子的右子树,先左旋,再右旋
  4. RL 型:插入右孩子的左子树,先右旋,再左旋

在这里插入图片描述

LL 型

  • 旧根节点(节点 3)为新根节点(节点 2)的右子树
  • 新根节点的 右子树(如果存在)为旧根节点的左子树
    在这里插入图片描述
    简单来说:

​ 先找到失衡树的根节点(Root),我们把他根节点的左子树称作为(temp)

那么temp 的父亲,变成他的右孩子

以上动图是最简单的方式

接下来如下图所示(一般情况,上面可以理解为右孙是NULL):
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
用代码来讲就是

/* 因为他是LL型,先获取原先根节点的左孩子, */
reeNode* temp = node -> lchild;
/* 爹的左子树现在变成 儿的右子树*/
node -> lchild = temp -> rchild; 
/* 儿的右子树变成爹*/
temp -> rchild = node;

因为我们本身是二叉排序树,所以爹一定是比儿大的,右孙也比儿大的,但是一定比爹小

所以爹的左子树从儿变成右孙,儿变爹,爹变儿,孙子永远还是孙子

也可以简单记为右旋

RR 型

  • 旧根节点(节点 1)为新根节点(节点 2)的左子树
  • 新根节点的左子树(如果存在)为旧根节点的右子树

在这里插入图片描述
简单来说:

​ 先找到失衡树的根节点(Root),我们把他根节点的左子树称作为(temp)

那么temp 的父亲,变成他的左孩子

以上动图是最简单的方式

接下来如下图所示(一般情况,上面可以理解为左孙是NULL):

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

用代码来讲就是

/* 因为他是RR型,先获取原先根节点的右孩子, */
reeNode* temp = node -> rchild;
/* 爹的右子树现在变成 儿的左子树*/
node -> rchild = temp -> lchild; 
/* 儿的左子树变成爹*/
temp -> lchild = node;

基本就是和LL型相反的,

也可以简单记为左旋

我们可以通过下面的图直观的感受到

在这里插入图片描述

LR 型

  • 旧根节点(节点 1)为新根节点(节点 2)的左子树
  • 新根节点的左子树(如果存在)为旧根节点的右子树

在这里插入图片描述

  • 根节点(节点 3)为新根节点(节点 2)的右子树
  • 新根节点的 右子树(如果存在)为旧根节点的左子树
    在这里插入图片描述
    接下来如下图所示(一般情况,上面可以理解为左右玄孙是NULL):

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
孙子终于当爹了,太感动了~

简单来讲:

​   取最后一个节点,作为父节点,将它的父亲作为自己的左孩子,将它的父亲的父亲作为自己的右孩子,如果它有左孩子或者右孩子的话,它原先的左孩子,连接到父亲的右孩子上,它现在的右孩子,连接到父亲的父亲的左孩子上

这里先买个关子,我们后面在讲代码,先看RL型的

RL型

  • 旧根节点(节点 3)为新根节点(节点 2)的右子树
  • 新根节点的 右子树(如果存在)为旧根节点的左子树
    在这里插入图片描述
  • 旧根节点(节点 1)为新根节点(节点 2)的左子树
  • 新根节点的左子树(如果存在)为旧根节点的右子树
    在这里插入图片描述
      简单来说,取最后一个节点,作为父亲节点,将它原先的父亲作为自己的右孩子,将父亲的父亲作为自己的左孩子,如果自己有左孩子或者右孩子的话,自己原先的左孩子连接到父亲的父亲有孩子上,自己原先的右孩子连接到父亲的左孩子上

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

往期回顾

1.【第一章】《线性表与顺序表》
2.【第一章】《单链表》
3.【第一章】《单链表的介绍》
4.【第一章】《单链表的基本操作》
5.【第一章】《单链表循环》
6.【第一章】《双链表》
7.【第一章】《双链表循环》
8.【第二章】《栈》
9.【第二章】《队》
10.【第二章】《字符串暴力匹配》
11.【第二章】《字符串kmp匹配》
12.【第三章】《树的基础概念》
13.【第三章】《二叉树的存储结构》
14.【第三章】《二叉树链式结构及实现1》
15.【第三章】《二叉树链式结构及实现2》
16.【第三章】《二叉树链式结构及实现3》
17.【第三章】《二叉树链式结构及实现4》
18.【第三章】《二叉树链式结构及实现5》
19.【第三章】《中序线索二叉树理论部分》
20.【第三章】《中序线索二叉树代码初始化及创树》
21.【第三章】《中序线索二叉树线索化及总代码》
22【第三章】《先序线索二叉树理论及线索化》
23【第三章】《先序线索二叉树查找及总代码》
24【第三章】《后续线索二叉树线索化理论》
25【第三章】《后续线索二叉树总代码部分》
26【第三章】《二叉排序树基础了解》
27【第三章】《二叉排序树代码部分》
28【第三章】《二叉排序树代码部分》
29【第三章】《平衡二叉树基础概念》
30【第三章】《平衡二叉树的平衡因子》
31【第三章】《平衡二叉树的旋转基础详解1》

  • 25
    点赞
  • 29
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值