当前位置: 首页 > news >正文

数据结构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旋转,都是最后一个结点当根节点,其余上层两个分别作为左右子树。新增结点,在左右子树根结点上两个哪个都可以。其余结点结构保持不变。

http://www.cnnetsun.cn/news/95921.html

相关文章:

  • 【收藏必备】零基础入门AI Agent:概念、结构、方法与开发框架全解析
  • vue基于Springboot框架实现新能源汽车4s店销售管理系统
  • 开关频率可调的永磁同步电机svpwm发电仿真模型,可调稳定发电电压,负载,母线电容可调,可用于...
  • C语言高阶玩法:函数指针与回调函数实战指南,让你的代码拥有“灵魂”
  • 基于SpringBoot的校园二手书交易平台的设计与实现
  • 数据结构与算法--007三数之和(medium)
  • C++ 模板初阶:泛型编程的入门指南
  • 基于Java实现优雅关闭的规范化方案设计与实现
  • 时序数据战场巅峰对决:金仓数据库 VS InfluxDB深度解析
  • Windows任务管理器中CPU相关指标怎么看?
  • 【必藏】大模型入行晚了?现在就是黄金时机!小白到入门的完整路线
  • 系统思考与认知习惯
  • 速藏!2026年免费免版权音乐素材网站推荐!正规版权保障,商用无压力不侵权
  • 【数据分享】1951-2024年我国省市县三级逐日、逐月和逐年近地面气温数据(Shp/Excel格式)
  • 金融行业广告投放:在合规的赛道上,实现精准增长
  • 长安汽车11月销量28.3万辆,同比增长2.3%
  • 1688 商品详情接口深度解析:从百川签名突破到供应链数据重构
  • LobeChat心理情绪日记分析工具
  • 一文搞懂纸老虎-布隆过滤器
  • LobeChat周年庆感恩回馈活动
  • 运维系列数据库系列【仅供参考】:DM JOB作业的邮件发送
  • 当AI面临伦理投诉时,AI应用架构师该怎么办?这5个解决步骤
  • 主存编址是什么
  • Python 整合 Redis 哨兵(Sentinel)与集群(Cluster)实战指南
  • HLS技术的局限性说明
  • 水文监测站:水资源管理的“千里眼”与“顺风耳”
  • 白银波动幅度大于黄金的原因:市场规模与属性差异深度解析
  • 【2026版】Spring Boot面试题
  • 办公小程序开发----提高工作效率
  • Jmeter 命令行压测生成HTML测试报告