AVL 树
AVL 树,是一种平衡的二叉搜索树。由于各种算法教材上对 AVL 的介绍十分冗长,造成了很多人对 AVL 树复杂、不实用的印象。但实际上,AVL 树的原理简单,实现也并不复杂。
性质
- 空二叉树是一个 AVL 树
- 如果 T 是一棵 AVL 树,那么其左右子树也是 AVL 树,并且
,h 是其左右子树的高度 - 树高为
平衡因子:右子树高度 - 左子树高度
树高的证明
设
根据常系数非齐次线性差分方程的解法,
斐波那契数列以指数的速度增长,对于树高
因此 AVL 树的高度为
过程
插入结点
与 BST(二叉搜索树)中类似,先进行一次失败的查找来确定插入的位置,插入节点后根据平衡因子来决定是否需要调整。
删除结点
删除和 BST 类似,将结点与后继交换后再删除。
删除会导致树高以及平衡因子变化,这时需要沿着被删除结点到根的路径来调整这种变化。
平衡的维护
插入或删除节点后,可能会造成 AVL 树的性质 2 被破坏。因此,需要沿着从被插入/删除的节点到根的路径对树进行维护。如果对于某一个节点,性质 2 不再满足,由于我们只插入/删除了一个节点,对树高的影响不超过 1,因此该节点的平衡因子的绝对值至多为 2。由于对称性,我们在此只讨论左子树的高度比右子树大 2 的情况,即下图中
设
其中
显然节点 A、C、E 的高度不发生变化,并且有
因此旋转后的节点 B 和 D 也满足性质 2。
$h(A)
本页面最近更新:2024/8/22 00:45:02,更新历史
发现错误?想一起完善? 在 GitHub 上编辑此页!
本页面贡献者:Ir1d, Wajov, Enter-tainer, mgt, RIvance, 5ab-juruo, ChungZH, diauweb, GoodCoder666, Great-designer, iamtwz, jimgreen2013, Tiphereth-A, Xeonacid
本页面的全部内容在 CC BY-SA 4.0 和 SATA 协议之条款下提供,附加条款亦可能应用