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 树的左旋转、右旋转》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!

查看所有标签

猜你喜欢:

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

新媒体文案创作与传播

新媒体文案创作与传播

秋叶、叶小鱼、勾俊伟 / 人民邮电出版社 / 2017-4 / 39.80元

《新媒体文案创作与传播》共分三篇。第1篇是新媒体文案基础篇,主要讲述了新媒体文案的基本概念、新媒体文案的岗位要求和职业能力素养;第二篇是新媒体文案创意实务篇,主要讲述了新媒体文案的创作思路、新媒体文案的写作技巧、爆款新媒体文案的打造、新媒体销售文案的写作、新媒体对文案传播的新要求、新媒体品-牌文案的写作,以及不同媒介的特征及发布形式;第三篇为新媒体文案相关技能补充,主要讲述的是策划能力。 《新媒体......一起来看看 《新媒体文案创作与传播》 这本书的介绍吧!

RGB转16进制工具
RGB转16进制工具

RGB HEX 互转工具

图片转BASE64编码
图片转BASE64编码

在线图片转Base64编码工具

随机密码生成器
随机密码生成器

多种字符组合密码