形态匀称的二叉树称为平衡二叉树 (Balanced binary tree) ,其严格定义是:
一棵空树是平衡二叉树;若 T 是一棵非空二叉树,其左、右子树为 TL 和 TR ,令 hl 和 hr 分别为左、右子树的深度。当且仅当
①TL 、 TR 都是平衡二叉树;
② | hl - hr |≤ 1;
时,则 T 是平衡二叉树。
【例】如图所示。
(a)平衡二叉树 (b)非平衡二叉树
图 平衡二叉树与非平衡二叉树
相应地定义 hl - hr 为二叉平衡树的平衡因子 (balance factor) 。因此,平衡二叉树上所有结点的平衡因子可能是 -1 , 0 , 1 。换言之,若一棵二叉树上任一结点的平衡因子的绝对值都不大于 1 ,则该树是就平衡二叉树。
1.动态平衡技术
Adelson-Velskii 和 Landis 提出了一个动态地保持二叉排序树平衡的方法,其基本思想是:
在构造二叉排序树的过程中,每当插入一个结点时,首先检查是否因插入而破坏了树的平衡性,如果是因插入结点而破坏了树的平衡性,则找出其中最小不平衡子树,在保持排序树特性的前提下,调整最小不平衡子树中各结点之间的连接关系,以达到新的平衡。通常将这样得到的平衡二叉排序树简称为 AVL 树。
2.最小不平衡子树
以离插入结点最近、且平衡因子绝对值大于 1 的结点作根结点的子树。为了简化讨论,不妨假设二叉排序树的最小不平衡子树的根结点为 A ,则调整该子树的规律可归纳为下列四种情况:
(1) LL 型:
新结点 X 插在 A 的左孩子的左子树里。调整方法见图 8.5(a) 。图中以 B 为轴心,将 A 结点从 B 的右上方转到 B 的右下侧,使 A 成为 B 的右孩子。
图8.5 平衡调整的4种基本类型(结点旁的数字是平衡因子)
(2)RR 型:
新结点 X 插在 A 的右孩子的右子树里。调整方法见图 8.5(b) 。图中以 B 为轴心,将 A 结点从 B 的左上方转到 B 的左下侧,使 A 成为 B 的左孩子。
(3)LR 型:
新结点 X 插在 A 的左孩子的右子树里。调整方法见图 8.5(c) 。分为两步进行:第一步以 X 为轴心,将 B 从 X 的左上方转到 X 的左下侧,使 B 成为 X 的左孩子, X 成为 A 的左孩子。第二步跟 LL 型一样处理 ( 应以 X 为轴心 ) 。
(4)RL 型:
新结点 X 插在 A 的右孩子的左子树里。调整方法见图 8.5(d) 。分为两步进行:第一步以 X 为轴心,将 B 从 X 的右上方转到 X 的右下侧,使 B 成为 X 的右孩子, X 成为 A 的右孩子。第二步跟 RR 型一样处理 ( 应以 X 为轴心 ) 。
【例】
实际的插入情况,可能比图 8.5 要复杂。因为 A 、 B 结点可能还会有子树。现举一例说明:
设一组记录的关键字按以下次序进行插入: 4 、 5 、 7 , 2 、 1 、 3 、 6 .
其生成及调整成二叉平衡树的过程示于图 8.6 。
在图 8.6 中,当插入关键字为3的结点后,由于离结点3最近的平衡因子为2的祖先是根结点5。所以,第一次旋转应以结点4为轴心,把结点2从结点4的左上方转到左下侧,从而结点5的左孩子是结点4,结点4的左孩子是结点2,原结点4的左孩子变成了结点2的右孩子。第二步再以结点4为轴心,按LL类型进行转换。这种插入与调整平衡的方法可以编成算法和程序,这里就不再讨论了。
图 8.6 二叉平衡树插入结点 ( 结点旁的数字为其平衡因子 )
- 大小: 17.5 KB
- 大小: 7.3 KB
- 大小: 7.5 KB
分享到:
相关推荐
平衡二叉树是一种特殊的二叉搜索树,它的主要特性是左右子树的高度差不超过1,这使得在平衡二叉树中的查找、插入和删除操作的时间复杂度都能保持在O(log n)。平衡二叉树的一个典型代表是AVL树,它在插入新节点后可能...
为了更高效地处理大数据,还可以考虑使用平衡二叉树,如AVL树或红黑树。 在PHP中实现二叉树,还需要考虑错误处理、内存管理以及如何将二叉树序列化和反序列化,以便在持久存储中保存和恢复。此外,还可以扩展这个...
平衡二叉树,如AVL树和红黑树,是为了保持查询效率而设计的,它们通过保持树的高度平衡来确保查找、插入和删除操作的时间复杂度为O(log n)。 在实际应用中,二叉树广泛用于文件系统、数据库索引、表达式求解、搜索...
1. **二叉树的创建**:学习如何通过动态内存分配和指针操作创建二叉树,包括插入新节点、删除节点以及构建平衡二叉树(如AVL树或红黑树)。 2. **二叉树遍历**:掌握前序遍历(根-左-右)、中序遍历(左-根-右)和...
平衡二叉树,如AVL树和红黑树,是为了保证查找效率而设计的,它们要求任意两个叶子节点之间的高度差不超过1,从而确保搜索性能接近最优。 二叉树的主要操作包括插入、删除和查找。插入操作是在树中找到合适的位置...
6. **性能评估**:设计完成后,需要通过测试和性能评估来验证线索二叉树在不同场景下的表现,对比其他数据结构,如普通二叉树、平衡二叉树等。 7. **扩展应用**:线索二叉树可以应用于实际问题,如文件系统的目录...
包括满二叉树(所有层都完全填充,除了可能的最后一层,且最后一层的所有节点都尽可能地靠左)、完全二叉树(除了最后一层,每一层都是完全填充的,并且所有的节点都尽可能地靠左)以及平衡二叉树(左右子树的高度差...
3. 平衡二叉树:左右两个子树的高度差不超过1,并且都是平衡二叉树。 二叉树的常用操作包括插入、删除、搜索等: 1. 插入节点:找到合适的位置将新节点添加,通常是在叶子节点处添加。 2. 删除节点:根据节点是否...
2. **树形数据结构**:书中重点讲述了二叉树,包括二叉搜索树、完全二叉树、满二叉树和平衡二叉树(如AVL树和红黑树)。二叉树是一种每个节点最多有两个子节点的数据结构,广泛应用于文件系统、数据库索引等场景。...
二叉树的主要特点包括:插入、删除和查找操作通常具有较高的效率,特别是对于平衡二叉树如AVL树或红黑树等。在家谱管理系统的背景下,二叉树可以用来表示家庭成员之间的关系,例如,每个节点代表一个家庭成员,父...
在计算机科学中,二叉树是数据结构的基础,广泛应用于搜索、排序、图解和表达式求值等领域。本文件重点探讨了二叉树的创建、遍历和删除等基本操作。 一、二叉树的创建 创建二叉树首先涉及节点的定义。一个二叉树...
常见的树类型有二叉树、二叉搜索树、平衡二叉树(AVL树、红黑树等)、B树、B+树等。在计算机科学中,树结构广泛应用于文件系统、数据库索引、编译器设计等领域。 5. **图**:图由顶点和边组成,可以表示实体之间的...
二叉树、平衡二叉树(如AVL树、红黑树)和B树等是常见的树型结构,它们在搜索、排序等方面有广泛应用。 6. **图**:由顶点和边构成,用于表示对象之间的关系。图可以是无向的,也可以是有向的,图的遍历算法如深度...
当树失去平衡(如图7-14(b)所示)时,可以通过旋转操作(如RR型调整)来重新平衡树,如图7-14(c)所示,这是维护平衡二叉树的关键步骤。 这些知识点对于数据结构和算法的学习,尤其是准备数据结构考试来说,是非常...
常见的树形结构有二叉树、平衡二叉树(如AVL树、红黑树)、B树和B+树,广泛应用于文件系统、数据库索引等领域。 6. **图**:由顶点和边组成的非线性数据结构,用于表示对象之间的关系。图可以用来解决许多实际问题...
平衡二叉树如AVL树和红黑树,通过保持高度平衡来确保高效的查找性能。多叉树,如B树和B+树,广泛应用于数据库索引。 图数据结构由节点(顶点)和边构成,可以表示复杂的关系网络。图的遍历算法如深度优先搜索(DFS...
二叉树的变体如平衡二叉树、红黑树、B+树等在实际应用中更为复杂且高效。 6. **散列表(哈希表)**:散列表通过哈希函数将键映射到数组位置,提供快速的查找。然而,由于哈希冲突,可能需要使用链表(拉链法)或...
数据结构与算法图解 数据结构是一种组织和管理数据的方式,它能够将抽象的数据以一种有效的方式存储在计算机内存中。数据结构用于描述和存储数据,包括数据的存储方式、数据的访问方式以及数据的操作方式。常见的...
二叉树是最常见的树类型,包括二叉搜索树、完全二叉树、满二叉树和平衡二叉树等。 8. **图**:由顶点和边构成的数据结构,用于表示对象之间的关系。图可以是无向的(边没有方向)或有向的(边有方向),并且可能...
常见的树类型包括二叉树、满二叉树、完全二叉树、平衡二叉树(如AVL树和红黑树)、B树和B+树等。二叉树的遍历方法有前序、中序和后序三种,它们在搜索算法中扮演着重要角色。而平衡二叉树的主要特点是保持左右子树的...