news 2026/4/15 12:06:47

数据结构05——平衡二叉树

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
数据结构05——平衡二叉树

数据结构——平衡二叉树

  • 平衡二叉树定义
  • AVL树
  • AVL树的调整
    • RR 右单旋
    • LL 左单旋
    • LR 旋转
    • RL 旋转
    • 总结

平衡二叉树定义

“平衡因子(Balanced Factor,简称BF)”:B F ( T ) = h L − h R BF(T)=h_L-h_RBF(T)=hLhR,其中h L h_LhLh R h_RhR分别为T的左、右子树的高度。

平衡二叉树(Balanced Binary Tree),是空树,或者任一结点左、右子树高度差的绝对值不超过1,即∣ B F ( T ) < = 1 ∣ |BF(T)<=1|BF(T)<=1∣


上图就不是平衡二叉树

AVL树

AVL 树(Adelson-Velsky and Landis Tree)是一种自平衡的二叉搜索树,对任意结点,其左右子树的高度差(平衡因子)绝对值不超过 1。
AVL= 平衡二叉树+二叉搜索(排序)树

AVL = 三位苏联学者的名字首字母
Adelson-Velsky
Velsky
Landis
📌 这是世界上第一种被提出的平衡二叉搜索树(1962 年)。

性质:给定结点数为n的AVL树的最大高度为O ( l o g 2 n ) O(log_2n)O(log2n)

AVL树的调整

当给一个AVL树插入一个新结点后,可能会出现不平衡的状态。此时,就需要进行旋转来调整,恢复道平衡的状态。

RR 右单旋

插入新结点后,
A是问题出现的结点,它的平衡因子变成了-2,由此出现了不平衡。
E是插入新结点的父结点。E在A的右子树的右结点,所以叫RR插入,需要进行RR旋转(右单旋)
F是新插入的结点,F的左右没有影响,主要是看E和A的位置关系。
D是这个变换中,唯一被更换父节点的结点

上图是AVL树RR旋转的最下端截取,因为AVL插入引起的不平衡一定是对最下端造成的影响,上层结点的平衡因子都被+1,只要解决这3层,上层的问题都被解决。

LL 左单旋

插入新结点后,
A是问题出现的结点,它的平衡因子变成了2,由此出现了不平衡。
D是新结点插入的结点。D在A的左子树的左结点,所以叫LL插入,需要进行LL旋转(左单旋)
F是新插入的结点
E是这个变换中,唯一被更换父节点的结点

LR 旋转

插入新结点后,
A是问题出现的结点,它的平衡因子变成了2,由此出现了不平衡。
E是新结点插入的结点。E在A的左子树的右结点,所以叫LR插入,需要进行LR旋转
F是新插入的结点

RL 旋转

插入新结点后,
A是问题出现的结点,它的平衡因子变成了-2,由此出现了不平衡。
D是新结点插入的结点。D在A的右子树的左结点,所以叫RL插入,需要进行RL旋转
F是新插入的结点

总结

RR和LL旋转,都是中间提起。中间结点多余原有的子树,直接接到原根节点上。其余结构保持不变。
RL和LR旋转,都是最后一个结点当根节点,其余上层两个分别作为左右子树。新增结点,在左右子树根结点上两个哪个都可以。其余结点结构保持不变。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/11 2:07:51

深入 Flutter 开发:构建一个带网络请求的天气应用(含完整代码)

标题&#xff1a;深入 Flutter 开发&#xff1a;构建一个带网络请求的天气应用&#xff08;含完整代码&#xff09; 引言 在移动开发领域&#xff0c;Flutter 凭借其高性能、跨平台能力和出色的 UI 表现力&#xff0c;已成为 Google 主推的现代应用开发框架。它使用 Dart 语言…

作者头像 李华
网站建设 2026/4/14 12:11:08

微算法科技(NASDAQ MLGO)链下与机器学习融合:革新区块链可扩展性

区块链技术自诞生以来&#xff0c;凭借去中心化、不可篡改的特性&#xff0c;在金融、供应链、版权保护等领域展现出颠覆性潜力。然而&#xff0c;随着用户规模与交易量的指数级增长&#xff0c;传统区块链架构逐渐暴露出可扩展性不足的瓶颈。公链网络每秒处理几十笔交易的能力…

作者头像 李华
网站建设 2026/4/8 8:52:20

考虑风光出力的虚拟电厂和运营商的主从博弈,分别考虑电动汽车充放电,火电出力,储能设备充放电充放...

考虑风光出力的虚拟电厂和运营商的主从博弈&#xff0c;分别考虑电动汽车充放电&#xff0c;火电出力&#xff0c;储能设备充放电充放电价格等因素外层用改进粒子群算法&#xff0c;目标函数线性加权。最近在折腾虚拟电厂和运营商的主从博弈模型&#xff0c;发现把风光出力、电…

作者头像 李华
网站建设 2026/4/9 13:11:00

不囤货、不开店,如何用一部手机连接1000家品牌

凌晨四点,陈明被一通电话吵醒。电话那头是仓库老王急促的声音:“陈总,那批饼干还有三天过期,今天再处理不掉,就只能当垃圾扔了!” 这已经是这个月第三次了。陈明烦躁地挂掉电话,看着仓库里堆积如山的临期货,心里像压了块石头。他是华南地区某知名饼干品牌的代理商,手里…

作者头像 李华
网站建设 2026/4/3 21:16:24

vue基于Springboot框架二手车托运物流管理系统

目录已开发项目效果实现截图开发技术系统开发工具&#xff1a;核心代码参考示例1.建立用户稀疏矩阵&#xff0c;用于用户相似度计算【相似度矩阵】2.计算目标用户与其他用户的相似度系统测试总结源码文档获取/同行可拿货,招校园代理 &#xff1a;文章底部获取博主联系方式&…

作者头像 李华
网站建设 2026/4/13 18:59:44

《Etsy 最狠的地方,不是封号,而是先让你注册成功》

如果你是第一次做 Etsy 买家账号&#xff0c;我可以先告诉你一个不太好听的事实&#xff1a; 你现在网上看到的注册教程&#xff0c;基本都已经失效了。 什么换个 IP 开无痕 一个邮箱一个号 这些在 Etsy 现在的风控体系里&#xff0c;几乎等于“裸奔注册”。一、新手最容易掉进…

作者头像 李华