第七章 查找 六、平衡二叉树

目录

一、定义

二、最小不平衡子树

1、平衡方法

2、查找效率

三、插入、删除操作

平衡二叉树的插入操作:

平衡二叉树的删除操作:

1、例子1

(1)若我们要删除9

(2)若我们要删除55

2、例子2

​编辑


一、定义

平衡二叉树是一种特殊的二叉树,具有如下性质:

  1. 它是一棵空树,或者它的左右两个子树的高度差的绝对值不超过 1,并且其左右两个子树都是平衡二叉树。

  2. 对于任意节点,它的左右两个子树的高度差都不超过 1。

平衡二叉树的主要作用是保持树的平衡,以确保操作的时间复杂度是 O(logn) 级别的。平衡二叉树的常见实现包括 AVL 树和红黑树等。

二、最小不平衡子树

1、平衡方法

(1)LL左孩子右旋

(2)RR右孩子左旋

(3)LR左孩子的右孩子先左后右

(4)RL右孩子的左孩子先右后左

2、查找效率

三、插入、删除操作

平衡二叉树的插入操作:

插入新结点后,要保持二叉排序树的特性不变(左<中<右)

若插入新结点导致不平衡,则需要调整平衡;

平衡二叉树的删除操作:

删除新结点后,要保持二叉排序树的特性不变(左<中<右)

若删除新结点导致不平衡,则需要调整平衡;

1、例子1

(1)若我们要删除9

从9开始往上寻找不平衡子树;

没有找到,就直接删除,不用调整平衡。

(2)若我们要删除55

在上面这个例子中,孙子在爷爷的右边的右边,所以为RR的情况。

把儿子进行左单旋,得到。

2、例子2

(1)若我们要删除32

我们找到44为最小不平衡子树的根结点

找到个头最高的儿子,和孙子

孙子在爷爷的右边的左边,为RL的形式

所以我们将孙子50先右旋再左旋,得到

相关推荐
磊 子6 小时前
AVL树的讲解
数据结构·算法
辞忧九千七6 小时前
吃透Redis7核心数据结构:从基础用法到实战场景(Python版)
开发语言·数据结构·redis·python
悠仁さん6 小时前
数据结构 树 二叉树 堆 (链式二叉树模拟实现篇)
数据结构·算法
better_liang6 小时前
每日Java面试场景题知识点之-MySQL底层数据结构B+树
java·数据结构·mysql·性能优化·面试题·b+树·数据库索引
洛水水6 小时前
【力扣100题】62.滑动窗口最大值
数据结构·算法·leetcode
浅念-7 小时前
LeetCode刷题专题:FloodFill泛滥填充算法剖析
数据结构·算法·leetcode·职场和发展·深度优先·宽度优先
兰令水9 小时前
leecodecode【滑动窗口】【2026.5.27打卡-java版本】
java·数据结构·算法
Brilliantwxx9 小时前
【算法题】 面试级别的二叉树题目OJ复习(上)
数据结构·c++·笔记·算法·面试
玖釉-21 小时前
下一个排列:从字典序到原地算法的完整推导
数据结构·c++·windows·算法
枕星而眠1 天前
数据结构八大排序详解(一):四大简单排序
c语言·数据结构·c++·后端