news 2026/3/10 23:06:34

数据结构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/3/8 19:19:53

comsol锂枝晶模型 五合一 单枝晶定向生长、多枝晶定向生长、多枝晶随机生长、无序生长随机形...

comsol锂枝晶模型 五合一 单枝晶定向生长、多枝晶定向生长、多枝晶随机生长、无序生长随机形核以及雪花枝晶&#xff0c;包含相场、浓度场和电场三种物理场&#xff08;雪花枝晶除外&#xff09;&#xff0c;其中单枝晶定向生长另外包含对应的参考文献。锂枝晶生长模型在电池失…

作者头像 李华
网站建设 2026/3/6 23:09:28

springboot在线影视论坛-计算机毕业设计源码71111

摘 要 随着互联网影视内容的快速发展&#xff0c;用户对影视作品的需求日益增多&#xff0c;尤其是通过在线平台来获取影视信息、评论与观看的需求日渐突出。因此&#xff0c;构建一个集影视信息管理、用户互动、社区功能于一体的在线影视论坛平台显得尤为重要。系统致力于为用…

作者头像 李华
网站建设 2026/3/10 16:03:19

RAG 2.0高级分块技术详解:9种策略+实战案例,让LLM应用性能翻倍(收藏)

本文详解RAG 2.0九种高级文本分块策略&#xff0c;包括滑动窗口、自适应、实体、主题、混合、任务感知、HTML/XML标签、代码专用和正则表达式切分。每种策略均配有适用场景、实现步骤和实例&#xff0c;帮助读者针对医疗、法律、新闻、研究论文等不同领域选择最优方案&#xff…

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

【Dify权限校验实战指南】:从零构建安全的检索结果访问控制体系

第一章&#xff1a;Dify权限校验的核心概念与架构解析Dify作为一个面向AI应用开发的低代码平台&#xff0c;其权限校验机制是保障系统安全与数据隔离的关键组成部分。该机制不仅支持多租户环境下的资源访问控制&#xff0c;还融合了角色、策略与上下文感知判断&#xff0c;实现…

作者头像 李华
网站建设 2026/3/9 10:30:03

基于Python的文件管理系统的设计与实现

文件管理系统的课题背景 随着信息技术的快速发展&#xff0c;数据量呈指数级增长&#xff0c;企业和个人对高效、安全的文件管理需求日益迫切。传统的文件管理方式&#xff0c;如手动分类存储或简单的文件夹管理&#xff0c;已难以应对海量数据的组织、检索和共享需求。特别是在…

作者头像 李华