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

目录

前言

一、为什么需要平衡?

二、两种旋转规则

规则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 的 孩子的子树上插入了新节点。

相关推荐
always_TT2 小时前
指针与结构体:链表节点设计
数据结构·链表
Yungoal2 小时前
数据结构综合0-排序
数据结构
西西弟2 小时前
最短路径之Floyd算法(数据结构)
数据结构·算法
SilentSlot2 小时前
【数据结构】红黑树定义及基本操作
数据结构
wangchunting3 小时前
数据结构-树
java·数据结构
Rabitebla3 小时前
归并排序(MergeSort)完全指南 —— 从原理到非递归实现
c语言·数据结构·c++·算法·排序算法
寒秋花开曾相惜3 小时前
(学习笔记)3.9 异质的数据结构(3.9.1 结构)
c语言·网络·数据结构·数据库·笔记·学习
Book思议-3 小时前
【数据结构】数组与特殊矩阵
数据结构·算法·矩阵
不吃蘑菇!4 小时前
LeetCode Hot 100-1(两数之和)
java·数据结构·算法·leetcode·哈希表