数据结构——平衡二叉树(AVL)

简介: 数据结构——平衡二叉树(AVL)

平衡二叉树

世界需要平衡,破坏平衡的一方,也许会一时很强势的称霸,最终的结局逃不过孤立和落空

定义

  • 左、右子树是平衡二叉树;
  • 所有结点的左、右子树深度之差的绝对值≤ 1
平衡因子:该结点左子树与右子树的高度差
  • 任一结点的平衡因子只能取:-1、0 或 1;如果树中任意一个结点的平衡因子的绝对值大于1,则这棵二叉树就失去平衡,不再是AVL树;
  • 对于一棵有n个结点的AVL树,其高度保持在O(log2n)数量级ASL也保持在O(log2n)量级

存储结构

typedef struct BSTNode{
    ElemType data;
    int bf;  // 平衡因子
    struct BSTNode* lchild, *rchild; 
} BSTNode, *BSTree;

平衡旋转


LL平衡旋转

  • LL型:定义失去平衡的最小子树根节点为a,则该类不平衡可归纳为,在a的左子树根节点的左子树上插入导致的不平衡可使用单向右旋平衡处理,可以记为左左->右
    在这里插入图片描述
    在这里插入图片描述

    在单向右旋平衡处理后BF(B)由1变为0,BF(A)由2变为0。

RR平衡旋转

  • RR型:在a的右子树根节点的右子树上插入导致的不平衡可使用单向左旋平衡处理,可以记为右右->左

在这里插入图片描述在这里插入图片描述

在单向左旋平衡处理后BF(B)由-1变为0,BF(A)由-2变为0。

---

LR平衡旋转

  • LR型:在3的左子树根节点1的右子树上插入节点2导致不平衡,可使用双向旋转:先使其子树左旋再整棵树右旋,可记为左右->左右

在这里插入图片描述在这里插入图片描述

在双向旋转平衡处理后BF(A)由2变为-1,BF(B)由-1变为0,BF(C)由1变为0。

RL平衡旋转

  • RL型:在19的右子树根节点25的左子树上插入节点23导致不平衡,可使用双向旋转:先使其子树右旋再整棵树左旋,可记为右左->右左

在这里插入图片描述在这里插入图片描述

在双向旋转平衡处理后BF(A)由-2变为0,BF(B)由1变为-1,BF(C)由1变为0。

旋转操作特点

  • 对不平衡的最小子树操作。
  • 旋转后子树根节点平衡因子为0。
  • 旋转后子树深度不变故不影响全树,也不影响插入路径上所有祖先结点的平衡度。

依次插入的关键字为5, 4, 2, 8, 6, 9
在这里插入图片描述

在这里插入图片描述

平衡二叉树插入算法思想

  • 若是空树,插入节点作为根节点,树深度加1。
  • 插入节点key值等于根节点key值,则不插入。
  • 插入节点key值小于根节点key值,插入在左子树上,左子树深加1并且:

    • 左子树深度<右子树深度
    • 插入前若根节点平衡因子为-1,插入后则改为0,树深不变。

    在这里插入图片描述

    • 左子树深度=右子树深度
    • 插入前若根节点平衡因子为0,插入后则改为1,树深加1。

    在这里插入图片描述

    • 左子树深度>右子树深度LL型
    • 插入前若根节点平衡因子为1,插入后其左子树的平衡因子为1(左左),则单向右旋,旋转后根节点和右子树的平衡因子改为0,树深不变。

    在这里插入图片描述

    • 左子树深度>右子树深度LR型
    • 插入前若根节点平衡因子为1,插入后左子树的平衡因子为-1(左右),则先左旋再右旋,旋转后根节点和其左子树的平衡因子改为0,右子树的平衡因子改为-1,树深不变。

    在这里插入图片描述

  • 插入节点key值大于根节点key值,插入在右子树上,方法类似

平衡二叉树的查找性能分析

  • 在平衡树上进行查找的过程和二叉排序树相同,因此,查找过程中和给定值进行比较的关键字的个数不超过平衡 树的深度。
在二叉平衡树上进行查找时,
查找过程中和给定值进行比较的关键字的个数和 log(n) 相当。

变种的AVL树——红黑树

  • 颜色特征:每个结点为“黑色”或“红色”
  • 根特征:根结点永远是“黑色”的
  • 外部特征:扩充外部叶结点都是空的“黑色”结点
  • 内部特征:“红色”结点的两个子结点都是“黑色”的,即:不允许两个连续的红色结点
  • 深度特征:对于每个结点,从该结点到其所有子孙叶结点的路径中所包含的黑色结点数量必须相同

在这里插入图片描述

目录
相关文章
|
3月前
|
存储 算法 数据管理
数据结构与算法学习二零:二叉排序树(BST)、平衡二叉树(AVL)
这篇文章通过需求分析、代码实现和测试验证,详细介绍了二叉排序树的创建、遍历和删除操作,以及二叉平衡树(AVL)的自平衡特性和单旋转操作,旨在提高树结构在数据管理中的效率和性能。
68 0
数据结构与算法学习二零:二叉排序树(BST)、平衡二叉树(AVL)
|
3月前
【高阶数据结构】二叉树进阶探秘:AVL树的平衡机制与实现详解(三)
【高阶数据结构】二叉树进阶探秘:AVL树的平衡机制与实现详解
|
3月前
【高阶数据结构】二叉树进阶探秘:AVL树的平衡机制与实现详解(二)
【高阶数据结构】二叉树进阶探秘:AVL树的平衡机制与实现详解
|
3月前
|
存储
【高阶数据结构】二叉树进阶探秘:AVL树的平衡机制与实现详解(一)
【高阶数据结构】二叉树进阶探秘:AVL树的平衡机制与实现详解
|
4月前
|
存储 C语言
数据结构基础详解(C语言): 树与二叉树的应用_哈夫曼树与哈夫曼曼编码_并查集_二叉排序树_平衡二叉树
本文详细介绍了树与二叉树的应用,涵盖哈夫曼树与哈夫曼编码、并查集以及二叉排序树等内容。首先讲解了哈夫曼树的构造方法及其在数据压缩中的应用;接着介绍了并查集的基本概念、存储结构及优化方法;随后探讨了二叉排序树的定义、查找、插入和删除操作;最后阐述了平衡二叉树的概念及其在保证树平衡状态下的插入和删除操作。通过本文,读者可以全面了解树与二叉树在实际问题中的应用技巧和优化策略。
|
5月前
|
C++ 容器
【数据结构】AVL树
【数据结构】AVL树
|
7月前
数据结构学习记录——平衡二叉树的调整(基本介绍、右单旋、左单旋、左右双旋、右左双旋、平衡因子的计算)
数据结构学习记录——平衡二叉树的调整(基本介绍、右单旋、左单旋、左右双旋、右左双旋、平衡因子的计算)
123 1
|
6月前
|
存储
【数据结构】AVL树——平衡二叉搜索树
【数据结构】AVL树——平衡二叉搜索树
|
7月前
数据结构篇:旋转操作在AVL树中的实现过程
数据结构篇:旋转操作在AVL树中的实现过程
51 0
|
8月前
|
存储 算法 C++
数据结构/C++:AVL树
数据结构/C++:AVL树
51 2