动画 | 什么是AVL树?| 算法必看系列四十一

简介: VL树是最早被发明的自平衡二叉查找树。在AVL树中,任一节点对应的两棵子树的最大高度差为1,因此它也被称为高度平衡树。本文主要为大家讲解AVL树的相关知识。

原文链接

前言

首先介绍下 二分搜索树 ,它又名有序二叉查找树,它的特点是左子树的节点值要小于父节点值,右子树的节点值要大于父节点值。基于这样的特点,我们在查找某个节点的时候,可以采取二分查找的思想快速找到这个节点,时间复杂度期望值是为O(log n),但是它有最坏的的情况下。

例如,输入数组[9,7,5,3,1],如果要满足二分搜索树的规则插入一个个节点,这样的二叉树会退化成一条线性表,待会查找元素的时候时间复杂度已达O(N)。
1.gif
所以针对这种情况,我们引申出了平衡二分搜索树,它每个节点的左右子树高度差不会超过1,它能在O(log n)内完成插入、查找和删除操作。平衡二分搜索树种类比较多,AVL树是其中的一种,但是它是最早被发明的自平衡二分搜索树。

AVL树也会被称为高度平衡树,因为它比二分搜索树多了一个特点:任一节点的左右子树高度差最大为1。如果以后去参赛,可以根据数据的情况更改高度差最大值,甚至也可以制定高度差相差几倍。

计算高度和平衡因子

计算高度是从叶子节点开始的,起始高度默认为1。然后计算叶子节点的父节点高度,比较左右子树的高度,采取最大值再加1就是这个节点的高度了。依此类推,直到整个树的顶点。
image.png
计算平衡因子也跟计算高度从叶子节点开始的,然后依次往父节点计算。节点的平衡因子公式是它左子树的高度减去它右子树的高度,有时候也会相反,可负数。

带有平衡因子-1、0或1的节点被认为是平衡的,即期望平衡节点的平衡因子的绝对值不会大于高度差最大值的。带有平衡因子-2或2的节点被认为是不平衡的,意味着需要重新调整这个树。平衡因子的绝对值最大值不会超过高度差最大值+1,说明这个数的任一节点的平衡因子不会出现-3或3。

如果改定高度差最大值为2,那么平衡因子会出现-3或3了,同时这个节点也是不平衡的,需要旋转调整。带有平衡因子-2、-1、0、1或2则被认为是平衡的。

动画

3.gif

Code

image.png

左旋转和右旋转

AVL树调整不平衡的节点分为左旋转和右旋转,却分四种情况:LL、RR、LR和RL。其中L是左旋转,R是右旋转。如何采取使用哪一种情况则看插入的节点在哪里。

image.png

如果插入的节点是再T2子树里面,T1、T2、T3和T4都代表一个子树。T2里面插入一个节点,这个子树的高度加1,再计算父节点的平衡因子。如果这个节点是平衡的,则更新这个节点的高度。然后再往上计算父节点的平衡因子,接着判断是否平衡,如果是平衡的则更新高度,直到是不平衡的则进行旋转操作。

看上面图中,节点9是不平衡的,需要进行旋转操作。那如何进行哪种情况操作呢?

看左右子树哪一个子树插入了一个节点,节点5的左子树高度加1,导致节点5的平衡因子由0变成1。为了让节点5的平衡因子可以由1变成0,则希望节点5的右子树可以高度加1,所以就向节点5的父节点9进行右旋转操作,重新调整平衡因子,节点5的平衡因子恢复为0。

image.png

如果是下面情况,则不能单纯的进行右旋转操作了。看下面途中,插入一个节点是在节点3右子树发生的,节点3的平衡因子由0变成-1,应该希望是节点3左子树的高度可以高点。所以对节点3进行左旋转操作。

image.png

对节点3进行左旋转操作之后,更新相应节点的高度和平衡因子。看下面图中,发现节点5的平衡因子由-1变成1了,为了让1变成0,则希望是节点5的右子树高度可以高一点,所以对节点9进行右旋转操作。

image.png

进行LR旋转的操作如下图,节点5的平衡因子已恢复为0,节点9由开始的不平衡已变成平衡。

image.png

动画

4.gif

Code

5.jpg

删除节点

AVL树的删除操作和二分搜索树一样,也分待删除结点的右子树为空、左子树为空和左右子树都不为空的情况。

那如何更新高度和平衡因子,不平衡的节点又如何调整为平衡的呢?和插入节点一样。

插入节点是插入一个节点后从叶子节点计算高度,然后再到父节点根据左右子树的高度计算平衡因子,接着更新高度,再到上一个父节点,直到整个二叉树的顶点。

删除节点可以看作是包含插入节点的,因为删除一个节点后会从左右子树中拉上来一个节点,不会再从叶子节点从新计算高度了,而是从左右子树开始接着更新高度和计算平衡因子。

动画

7.gif

Code

6.jpg

来源 | 算法无遗策
作者 | 我脱下短袖

相关文章
|
4月前
|
存储 机器学习/深度学习 监控
网络管理监控软件的 C# 区间树性能阈值查询算法
针对网络管理监控软件的高效区间查询需求,本文提出基于区间树的优化方案。传统线性遍历效率低,10万条数据查询超800ms,难以满足实时性要求。区间树以平衡二叉搜索树结构,结合节点最大值剪枝策略,将查询复杂度从O(N)降至O(logN+K),显著提升性能。通过C#实现,支持按指标类型分组建树、增量插入与多维度联合查询,在10万记录下查询耗时仅约2.8ms,内存占用降低35%。测试表明,该方案有效解决高负载场景下的响应延迟问题,助力管理员快速定位异常设备,提升运维效率与系统稳定性。
275 4
|
9月前
|
存储 机器学习/深度学习 算法
KMP、Trie树 、AC自动机‌ ,三大算法实现 优雅 过滤 netty 敏感词
KMP、Trie树 、AC自动机‌ ,三大算法实现 优雅 过滤 netty 敏感词
KMP、Trie树 、AC自动机‌ ,三大算法实现 优雅 过滤 netty  敏感词
|
7月前
|
监控 算法 安全
基于 C# 基数树算法的网络屏幕监控敏感词检测技术研究
随着数字化办公和网络交互迅猛发展,网络屏幕监控成为信息安全的关键。基数树(Trie Tree)凭借高效的字符串处理能力,在敏感词检测中表现出色。结合C#语言,可构建高时效、高准确率的敏感词识别模块,提升网络安全防护能力。
193 2
|
9月前
|
监控 算法 数据处理
基于 C++ 的 KD 树算法在监控局域网屏幕中的理论剖析与工程实践研究
本文探讨了KD树在局域网屏幕监控中的应用,通过C++实现其构建与查询功能,显著提升多维数据处理效率。KD树作为一种二叉空间划分结构,适用于屏幕图像特征匹配、异常画面检测及数据压缩传输优化等场景。相比传统方法,基于KD树的方案检索效率提升2-3个数量级,但高维数据退化和动态更新等问题仍需进一步研究。未来可通过融合其他数据结构、引入深度学习及开发增量式更新算法等方式优化性能。
234 17
|
9月前
|
存储 监控 算法
局域网上网记录监控的 C# 基数树算法高效检索方案研究
在企业网络管理与信息安全领域,局域网上网记录监控是维护网络安全、规范网络行为的关键举措。随着企业网络数据量呈指数级增长,如何高效存储和检索上网记录数据成为亟待解决的核心问题。基数树(Trie 树)作为一种独特的数据结构,凭借其在字符串处理方面的卓越性能,为局域网上网记录监控提供了创新的解决方案。本文将深入剖析基数树算法的原理,并通过 C# 语言实现的代码示例,阐述其在局域网上网记录监控场景中的具体应用。
207 7
|
11月前
|
人工智能 算法 语音技术
Video-T1:视频生成实时手术刀!清华腾讯「帧树算法」终结闪烁抖动
清华大学与腾讯联合推出的Video-T1技术,通过测试时扩展(TTS)和Tree-of-Frames方法,显著提升视频生成的连贯性与文本匹配度,为影视制作、游戏开发等领域带来突破性解决方案。
382 4
Video-T1:视频生成实时手术刀!清华腾讯「帧树算法」终结闪烁抖动
|
8月前
|
机器学习/深度学习 算法 搜索推荐
决策树算法如何读懂你的购物心理?一文看懂背后的科学
"你为什么总能收到刚好符合需求的商品推荐?你有没有好奇过,为什么刚浏览过的商品就出现了折扣通知?
246 0
|
11月前
|
算法 Java
算法系列之数据结构-Huffman树
Huffman树(哈夫曼树)又称最优二叉树,是一种带权路径长度最短的二叉树,常用于信息传输、数据压缩等方面。它的构造基于字符出现的频率,通过将频率较低的字符组合在一起,最终形成一棵树。在Huffman树中,每个叶节点代表一个字符,而每个字符的编码则是从根节点到叶节点的路径所对应的二进制序列。
353 3
 算法系列之数据结构-Huffman树
|
12月前
|
算法 数据可视化 数据安全/隐私保护
一级倒立摆平衡控制系统MATLAB仿真,可显示倒立摆平衡动画,对比极点配置,线性二次型,PID,PI及PD五种算法
本课题基于MATLAB对一级倒立摆控制系统进行升级仿真,增加了PI、PD控制器,并对比了极点配置、线性二次型、PID、PI及PD五种算法的控制效果。通过GUI界面显示倒立摆动画和控制输出曲线,展示了不同控制器在偏转角和小车位移变化上的性能差异。理论部分介绍了倒立摆系统的力学模型,包括小车和杆的动力学方程。核心程序实现了不同控制算法的选择与仿真结果的可视化。
889 15
|
存储 算法 测试技术
【C++数据结构——树】二叉树的遍历算法(头歌教学实验平台习题) 【合集】
本任务旨在实现二叉树的遍历,包括先序、中序、后序和层次遍历。首先介绍了二叉树的基本概念与结构定义,并通过C++代码示例展示了如何定义二叉树节点及构建二叉树。接着详细讲解了四种遍历方法的递归实现逻辑,以及层次遍历中队列的应用。最后提供了测试用例和预期输出,确保代码正确性。通过这些内容,帮助读者理解并掌握二叉树遍历的核心思想与实现技巧。
597 3