AVL 树的左旋转、右旋转

栏目: 编程工具 · 发布时间: 5年前

内容简介:在文章什么是 AVL 树?中,我们讲解了 AVL 树的基本概念,以及它存在的意义。这篇文章,我们来讲解如何维护 AVL 树的平衡性。AVL树是一棵「自平衡」的 BST(二分搜索树),也就说,它需要一种机制来维护 BST 的平衡性。这种机制就是左旋转和右旋转。右旋转「旋转」其实就是移动 BST 中节点的位置,使节点的平衡因子为0、-1、1。当左子树发生不平衡,需要使用右旋转来达到平衡性。图中的节点 Y(4)为不平衡节点,T1,T2,T3,T4 均平衡,满足 T1 < z < T2 < x < T3 < y <

在文章什么是 AVL 树?中,我们讲解了 AVL 树的基本概念,以及它存在的意义。这篇文章,我们来讲解如何维护 AVL 树的平衡性。AVL树是一棵「自平衡」的 BST(二分搜索树),也就说,它需要一种机制来维护 BST 的平衡性。这种机制就是左旋转和右旋转。

右旋转

「旋转」其实就是移动 BST 中节点的位置,使节点的平衡因子为0、-1、1。当左子树发生不平衡,需要使用右旋转来达到平衡性。图中的节点 Y(4)为不平衡节点,T1,T2,T3,T4 均平衡,满足 T1 < z < T2 < x < T3 < y < T4。

AVL 树的左旋转、右旋转

右旋转其实很简单,按照下面的操作即可:


 

TreeNode *t3 = x.right;

x.right = y;

y.left = t3;

旋转后的 AVL 树是这样的,旋转后任然满足 BST 的条件,可以通过 T1 < z < T2 < x < T3 < y < T4 这个条件推导:

AVL 树的左旋转、右旋转

左旋转

当右子树发生不平衡时, 右子树的高度比左子树的高度大于 1 ,需要进行「左旋转」。比如下面这颗树失去了平衡性,不平衡节点为 Y,满足:T4<Y<T3<X<T2<Z<T1:

AVL 树的左旋转、右旋转

左旋转其实很简单,按照下面的操作即可:


 

TreeNode *t3 = x.left;

x.left = y;

y.right = t3;

旋转后的 AVL 树是这样的,旋转后任然满足 BST 的条件:

AVL 树的左旋转、右旋转

至此,我们学习了什么是 AVL 树,当由于插入新节点破坏 AVL 树的平衡性后(平衡因子不为 -1、0、1),通过左、右旋转来重新达到平衡性。 前面我们也动手用 Swift 实现了一颗 BST(二分搜索树) 使用 Swift 实现一颗二分搜索树 这一切其实都是为了下一篇文章做准备: 用 Swift 实现一颗 AVL 树。

推荐阅读:

图解数据结构和算法

AVL 树的左旋转、右旋转


以上所述就是小编给大家介绍的《AVL 树的左旋转、右旋转》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

敏捷估计与规划

敏捷估计与规划

[美] Mike Cohn / 宋锐 / 清华大学出版社 / 2007-7 / 39.90元

《敏捷估计与规划》一书为对敏捷项目进行估计与规划提供了权威实际的指导方针。在本书中,敏捷联盟的共同创始人Mike Cohn讨论了敏捷估计与规划的思想,并使用现实的例子与案例分析向您详细地展示了如何完成工作。本书清晰地阐述了有关的概念,并引导读者逐步认识到下列一些问题的答案:我们要构建什么?它的规模有多大?需要在什么时候完成?到那个时候我们到底能完成多少?您首先会认识到优秀的计划由哪些东西组成,接着......一起来看看 《敏捷估计与规划》 这本书的介绍吧!

JSON 在线解析
JSON 在线解析

在线 JSON 格式化工具

Markdown 在线编辑器
Markdown 在线编辑器

Markdown 在线编辑器

HEX CMYK 转换工具
HEX CMYK 转换工具

HEX CMYK 互转工具