【数据结构】平衡二叉树的旋转机制

目录

前言

一、为什么需要平衡?

二、两种旋转规则

规则1.左旋

规则2:右旋

三、需要旋转的四种场景

1、LL型失衡:右旋 (Right Rotation)

2、LR型失衡:先左旋,再右旋 (Left-Right Rotation)

3、RR型失衡:左旋 (Left Rotation)

4、RL型失衡:先右旋,再左旋 (Right-Left Rotation)


前言

在 Java 的集合框架中,TreeSetTreeMap 拥有自动排序的能力,这一切的根基,都建立在一种数据结构之上------平衡二叉树(AVL树)。今天来介绍一下408最爱的平衡二叉树的四种旋转机制。

一、为什么需要平衡?

在了解旋转之前,我们先看看普通的**二叉查找树(BST)**有什么致命缺陷。

二叉查找树的规则很简单:左子节点 < 父节点 < 右子节点。 这看起来很完美,每次查找都能排除一半的数据。但如果你按顺序插入一组数据:

它会一直往右边长,彻底退化成一条单向链表

为了防止这种的情况,AVL树(平衡二叉树) 诞生了。它给自己定下了一条规则: 任何节点的左子树和右子树的高度差,绝对不能超过 1。 一旦超过 1,它就会触发修复机制------旋转

二、两种旋转规则

旋转机制以及触发规则:

  • 规则1:左旋
  • 规则2:右旋
  • 触发规则:当添加一个节点后,该二叉树不再是一个平衡二叉树。

规则1.左旋

普通场景:

当12这个节点加入这个平衡二叉树后,破坏了二叉树的平衡状态:

确定支点:

从添加的节点开始往父节点找,找到的第一个不平衡的节点,即为支点。

在本例中节点10为支点,以10为支点向左旋转:

步骤:

1:以不平衡的点作为支点。

2:把支点左旋降级,变成左子节点。

3:晋升原来的右子节点。

特殊场景:

步骤:

1:以不平衡的点作为支点。

2:将根节点的右侧往左拉。

3:原先的右子节点变成新的父节点,并把多出来的左子节点,给已经降级的根节点当右子节点。

规则2:右旋

步骤:

1:以不平衡的点作为支点。

2:把支点右旋降级,变成右子节点。

3:晋升原来的左子节点。

三、需要旋转的四种场景

1、LL型失衡:右旋 (Right Rotation)

场景: 在节点 A 的 孩子的子树上插入了新节点,导致 A 的左边太重了。

一次右旋

2、LR型失衡:先左旋,再右旋 (Left-Right Rotation)

场景: 在节点 A 的 孩子的子树上插入了新节点,破坏了二叉树的平衡状态。

3、RR型失衡:左旋 (Left Rotation)

场景: 在节点 A 的 孩子的子树上插入了新节点,导致 A 的右边太重了。

4、RL型失衡:先右旋,再左旋 (Right-Left Rotation)

场景: 在节点 A 的 孩子的子树上插入了新节点。

相关推荐
Darling噜啦啦5 天前
列表转树算法深度解析:从 Map 到 Reduce 的两种实现,面试高频考点
数据结构·算法·面试
小小工匠6 天前
Redis - 事务机制:能实现 ACID 属性吗
数据结构·redis·性能优化·并发·持久化
玖玥拾6 天前
C/C++ 数据结构(七)栈、容器适配器
c语言·数据结构·c++··容器适配器
Qres8216 天前
算法复键——树状数组
数据结构·算法
牛油果子哥q6 天前
并查集(DSU)超精讲,路径压缩、按秩合并、万能模板、连通性判定、最小生成树与刷题实战全解
数据结构·c++·最小生成树·并查集
凌波粒6 天前
LeetCode--491.递增子序列(回溯算法)
数据结构·算法·leetcode
WL学习笔记6 天前
单项不带头不循环链表
数据结构·链表
小糯米6016 天前
JS 数组
数据结构·算法·排序算法
小欣加油6 天前
leetcode3612 用特殊操作处理字符串I
数据结构·c++·算法·leetcode·职场和发展
凌波粒6 天前
LeetCode--90.子集II(回溯算法)
数据结构·算法·leetcode