This commit is contained in:
krahets
2023-04-17 18:24:27 +08:00
parent f76b7ed47c
commit ca2ccfea0b
70 changed files with 12269 additions and 13539 deletions

View File

@@ -25,7 +25,7 @@
<title>7.4.   AVL 树 * - Hello 算法</title>
<title>8.4.   AVL 树 * - Hello 算法</title>
@@ -79,7 +79,7 @@
<div data-md-component="skip">
<a href="#74-avl" class="md-skip">
<a href="#84-avl" class="md-skip">
跳转至
</a>
@@ -113,7 +113,7 @@
<div class="md-header__topic" data-md-component="header-topic">
<span class="md-ellipsis">
7.4. &nbsp; AVL 树 *
8.4. &nbsp; AVL 树 *
</span>
</div>
@@ -441,8 +441,6 @@
<label class="md-nav__link" for="__nav_3" id="__nav_3_label" tabindex="0">
@@ -504,23 +502,9 @@
<li class="md-nav__item">
<a href="../../chapter_computational_complexity/space_time_tradeoff/" class="md-nav__link">
2.4. &nbsp; 权衡时间与空间
</a>
</li>
<li class="md-nav__item">
<a href="../../chapter_computational_complexity/summary/" class="md-nav__link">
2.5. &nbsp; 小结
2.4. &nbsp; 小结
</a>
</li>
@@ -847,21 +831,76 @@
<label class="md-nav__link" for="__nav_7" id="__nav_7_label" tabindex="0">
6. &nbsp; &nbsp; 散列表
6. &nbsp; &nbsp; 二分查找
<span class="md-nav__icon md-icon"></span>
</label>
<nav class="md-nav" data-md-level="1" aria-labelledby="__nav_7_label" aria-expanded="false">
<label class="md-nav__title" for="__nav_7">
<span class="md-nav__icon md-icon"></span>
6. &nbsp; &nbsp; 散列表
6. &nbsp; &nbsp; 二分查找
</label>
<ul class="md-nav__list" data-md-scrollfix>
<li class="md-nav__item">
<a href="../../chapter_binary_search/binary_search/" class="md-nav__link">
6.1. &nbsp; 二分查找
</a>
</li>
</ul>
</nav>
</li>
<li class="md-nav__item md-nav__item--section md-nav__item--nested">
<input class="md-nav__toggle md-toggle " type="checkbox" id="__nav_8" >
<label class="md-nav__link" for="__nav_8" id="__nav_8_label" tabindex="0">
7. &nbsp; &nbsp; 散列表
<span class="md-nav__icon md-icon"></span>
</label>
<nav class="md-nav" data-md-level="1" aria-labelledby="__nav_8_label" aria-expanded="false">
<label class="md-nav__title" for="__nav_8">
<span class="md-nav__icon md-icon"></span>
7. &nbsp; &nbsp; 散列表
</label>
<ul class="md-nav__list" data-md-scrollfix>
@@ -872,7 +911,7 @@
<li class="md-nav__item">
<a href="../../chapter_hashing/hash_map/" class="md-nav__link">
6.1. &nbsp; 哈希表
7.1. &nbsp; 哈希表
</a>
</li>
@@ -886,7 +925,7 @@
<li class="md-nav__item">
<a href="../../chapter_hashing/hash_collision/" class="md-nav__link">
6.2. &nbsp; 哈希冲突处理
7.2. &nbsp; 哈希冲突处理
</a>
</li>
@@ -900,7 +939,7 @@
<li class="md-nav__item">
<a href="../../chapter_hashing/summary/" class="md-nav__link">
6.3. &nbsp; 小结
7.3. &nbsp; 小结
</a>
</li>
@@ -930,7 +969,7 @@
<input class="md-nav__toggle md-toggle " type="checkbox" id="__nav_8" checked>
<input class="md-nav__toggle md-toggle " type="checkbox" id="__nav_9" checked>
@@ -946,15 +985,15 @@
<label class="md-nav__link" for="__nav_8" id="__nav_8_label" tabindex="0">
7. &nbsp; &nbsp;
<label class="md-nav__link" for="__nav_9" id="__nav_9_label" tabindex="0">
8. &nbsp; &nbsp;
<span class="md-nav__icon md-icon"></span>
</label>
<nav class="md-nav" data-md-level="1" aria-labelledby="__nav_8_label" aria-expanded="true">
<label class="md-nav__title" for="__nav_8">
<nav class="md-nav" data-md-level="1" aria-labelledby="__nav_9_label" aria-expanded="true">
<label class="md-nav__title" for="__nav_9">
<span class="md-nav__icon md-icon"></span>
7. &nbsp; &nbsp;
8. &nbsp; &nbsp;
</label>
<ul class="md-nav__list" data-md-scrollfix>
@@ -965,7 +1004,7 @@
<li class="md-nav__item">
<a href="../binary_tree/" class="md-nav__link">
7.1. &nbsp; 二叉树
8.1. &nbsp; 二叉树
</a>
</li>
@@ -979,7 +1018,7 @@
<li class="md-nav__item">
<a href="../binary_tree_traversal/" class="md-nav__link">
7.2. &nbsp; 二叉树遍历
8.2. &nbsp; 二叉树遍历
</a>
</li>
@@ -993,7 +1032,7 @@
<li class="md-nav__item">
<a href="../binary_search_tree/" class="md-nav__link">
7.3. &nbsp; 二叉搜索树
8.3. &nbsp; 二叉搜索树
</a>
</li>
@@ -1016,12 +1055,12 @@
<label class="md-nav__link md-nav__link--active" for="__toc">
7.4. &nbsp; AVL 树 *
8.4. &nbsp; AVL 树 *
<span class="md-nav__icon md-icon"></span>
</label>
<a href="./" class="md-nav__link md-nav__link--active">
7.4. &nbsp; AVL 树 *
8.4. &nbsp; AVL 树 *
</a>
@@ -1040,11 +1079,11 @@
<ul class="md-nav__list" data-md-component="toc" data-md-scrollfix>
<li class="md-nav__item">
<a href="#741-avl" class="md-nav__link">
7.4.1. &nbsp; AVL 树常见术语
<a href="#841-avl" class="md-nav__link">
8.4.1. &nbsp; AVL 树常见术语
</a>
<nav class="md-nav" aria-label="7.4.1. &nbsp; AVL 树常见术语">
<nav class="md-nav" aria-label="8.4.1. &nbsp; AVL 树常见术语">
<ul class="md-nav__list">
<li class="md-nav__item">
@@ -1067,11 +1106,11 @@
</li>
<li class="md-nav__item">
<a href="#742-avl" class="md-nav__link">
7.4.2. &nbsp; AVL 树旋转
<a href="#842-avl" class="md-nav__link">
8.4.2. &nbsp; AVL 树旋转
</a>
<nav class="md-nav" aria-label="7.4.2. &nbsp; AVL 树旋转">
<nav class="md-nav" aria-label="8.4.2. &nbsp; AVL 树旋转">
<ul class="md-nav__list">
<li class="md-nav__item">
@@ -1115,11 +1154,11 @@
</li>
<li class="md-nav__item">
<a href="#743-avl" class="md-nav__link">
7.4.3. &nbsp; AVL 树常用操作
<a href="#843-avl" class="md-nav__link">
8.4.3. &nbsp; AVL 树常用操作
</a>
<nav class="md-nav" aria-label="7.4.3. &nbsp; AVL 树常用操作">
<nav class="md-nav" aria-label="8.4.3. &nbsp; AVL 树常用操作">
<ul class="md-nav__list">
<li class="md-nav__item">
@@ -1149,8 +1188,8 @@
</li>
<li class="md-nav__item">
<a href="#744-avl" class="md-nav__link">
7.4.4. &nbsp; AVL 树典型应用
<a href="#844-avl" class="md-nav__link">
8.4.4. &nbsp; AVL 树典型应用
</a>
</li>
@@ -1171,94 +1210,7 @@
<li class="md-nav__item">
<a href="../summary/" class="md-nav__link">
7.5. &nbsp; 小结
</a>
</li>
</ul>
</nav>
</li>
<li class="md-nav__item md-nav__item--section md-nav__item--nested">
<input class="md-nav__toggle md-toggle " type="checkbox" id="__nav_9" >
<label class="md-nav__link" for="__nav_9" id="__nav_9_label" tabindex="0">
8. &nbsp; &nbsp;
<span class="md-nav__icon md-icon"></span>
</label>
<nav class="md-nav" data-md-level="1" aria-labelledby="__nav_9_label" aria-expanded="false">
<label class="md-nav__title" for="__nav_9">
<span class="md-nav__icon md-icon"></span>
8. &nbsp; &nbsp;
</label>
<ul class="md-nav__list" data-md-scrollfix>
<li class="md-nav__item">
<a href="../../chapter_heap/heap/" class="md-nav__link">
8.1. &nbsp;
</a>
</li>
<li class="md-nav__item">
<a href="../../chapter_heap/build_heap/" class="md-nav__link">
8.2. &nbsp; 建堆操作 *
</a>
</li>
<li class="md-nav__item">
<a href="../../chapter_heap/summary/" class="md-nav__link">
8.3. &nbsp; 小结
8.5. &nbsp; 小结
</a>
</li>
@@ -1296,19 +1248,17 @@
<label class="md-nav__link" for="__nav_10" id="__nav_10_label" tabindex="0">
9. &nbsp; &nbsp;
9. &nbsp; &nbsp;
<span class="md-nav__icon md-icon"></span>
</label>
<nav class="md-nav" data-md-level="1" aria-labelledby="__nav_10_label" aria-expanded="false">
<label class="md-nav__title" for="__nav_10">
<span class="md-nav__icon md-icon"></span>
9. &nbsp; &nbsp;
9. &nbsp; &nbsp;
</label>
<ul class="md-nav__list" data-md-scrollfix>
@@ -1318,8 +1268,8 @@
<li class="md-nav__item">
<a href="../../chapter_graph/graph/" class="md-nav__link">
9.1. &nbsp;
<a href="../../chapter_heap/heap/" class="md-nav__link">
9.1. &nbsp;
</a>
</li>
@@ -1332,8 +1282,8 @@
<li class="md-nav__item">
<a href="../../chapter_graph/graph_operations/" class="md-nav__link">
9.2. &nbsp; 图基础操作
<a href="../../chapter_heap/build_heap/" class="md-nav__link">
9.2. &nbsp; 建堆操作 *
</a>
</li>
@@ -1346,22 +1296,8 @@
<li class="md-nav__item">
<a href="../../chapter_graph/graph_traversal/" class="md-nav__link">
9.3. &nbsp; 图的遍历
</a>
</li>
<li class="md-nav__item">
<a href="../../chapter_graph/summary/" class="md-nav__link">
9.4. &nbsp; 小结
<a href="../../chapter_heap/summary/" class="md-nav__link">
9.3. &nbsp; 小结
</a>
</li>
@@ -1404,14 +1340,14 @@
<label class="md-nav__link" for="__nav_11" id="__nav_11_label" tabindex="0">
10. &nbsp; &nbsp; 查找算法
10. &nbsp; &nbsp;
<span class="md-nav__icon md-icon"></span>
</label>
<nav class="md-nav" data-md-level="1" aria-labelledby="__nav_11_label" aria-expanded="false">
<label class="md-nav__title" for="__nav_11">
<span class="md-nav__icon md-icon"></span>
10. &nbsp; &nbsp; 查找算法
10. &nbsp; &nbsp;
</label>
<ul class="md-nav__list" data-md-scrollfix>
@@ -1421,8 +1357,8 @@
<li class="md-nav__item">
<a href="../../chapter_searching/linear_search/" class="md-nav__link">
10.1. &nbsp; 线性查找
<a href="../../chapter_graph/graph/" class="md-nav__link">
10.1. &nbsp;
</a>
</li>
@@ -1435,8 +1371,8 @@
<li class="md-nav__item">
<a href="../../chapter_searching/binary_search/" class="md-nav__link">
10.2. &nbsp; 二分查找
<a href="../../chapter_graph/graph_operations/" class="md-nav__link">
10.2. &nbsp; 图基础操作
</a>
</li>
@@ -1449,8 +1385,8 @@
<li class="md-nav__item">
<a href="../../chapter_searching/hashing_search/" class="md-nav__link">
10.3. &nbsp; 哈希查找
<a href="../../chapter_graph/graph_traversal/" class="md-nav__link">
10.3. &nbsp; 图的遍历
</a>
</li>
@@ -1463,7 +1399,7 @@
<li class="md-nav__item">
<a href="../../chapter_searching/summary/" class="md-nav__link">
<a href="../../chapter_graph/summary/" class="md-nav__link">
10.4. &nbsp; 小结
</a>
</li>
@@ -1605,7 +1541,7 @@
<li class="md-nav__item">
<a href="../../chapter_sorting/bucket_sort/" class="md-nav__link">
11.6. &nbsp; 桶排序New
11.6. &nbsp; 桶排序
</a>
</li>
@@ -1619,7 +1555,7 @@
<li class="md-nav__item">
<a href="../../chapter_sorting/counting_sort/" class="md-nav__link">
11.7. &nbsp; 计数排序New
11.7. &nbsp; 计数排序
</a>
</li>
@@ -1633,7 +1569,7 @@
<li class="md-nav__item">
<a href="../../chapter_sorting/radix_sort/" class="md-nav__link">
11.8. &nbsp; 基数排序New
11.8. &nbsp; 基数排序
</a>
</li>
@@ -1681,17 +1617,21 @@
<label class="md-nav__link" for="__nav_13" id="__nav_13_label" tabindex="0">
12. &nbsp; &nbsp; 回溯算法
12. &nbsp; &nbsp; 搜索算法
<span class="md-nav__icon md-icon"></span>
</label>
<nav class="md-nav" data-md-level="1" aria-labelledby="__nav_13_label" aria-expanded="false">
<label class="md-nav__title" for="__nav_13">
<span class="md-nav__icon md-icon"></span>
12. &nbsp; &nbsp; 回溯算法
12. &nbsp; &nbsp; 搜索算法
</label>
<ul class="md-nav__list" data-md-scrollfix>
@@ -1701,8 +1641,36 @@
<li class="md-nav__item">
<a href="../../chapter_backtracking/backtracking_algorithm/" class="md-nav__link">
12.1. &nbsp; 回溯算法New
<a href="../../chapter_searching/searching_algorithm_revisited/" class="md-nav__link">
12.1. &nbsp; 搜索算法New
</a>
</li>
<li class="md-nav__item">
<a href="../../chapter_searching/replace_linear_by_hashing/" class="md-nav__link">
12.2. &nbsp; 哈希优化策略
</a>
</li>
<li class="md-nav__item">
<a href="../../chapter_searching/summary/" class="md-nav__link">
12.3. &nbsp; 小结
</a>
</li>
@@ -1736,19 +1704,17 @@
<label class="md-nav__link" for="__nav_14" id="__nav_14_label" tabindex="0">
13. &nbsp; &nbsp; 附录
13. &nbsp; &nbsp; 回溯算法
<span class="md-nav__icon md-icon"></span>
</label>
<nav class="md-nav" data-md-level="1" aria-labelledby="__nav_14_label" aria-expanded="false">
<label class="md-nav__title" for="__nav_14">
<span class="md-nav__icon md-icon"></span>
13. &nbsp; &nbsp; 附录
13. &nbsp; &nbsp; 回溯算法
</label>
<ul class="md-nav__list" data-md-scrollfix>
@@ -1758,22 +1724,8 @@
<li class="md-nav__item">
<a href="../../chapter_appendix/installation/" class="md-nav__link">
13.1. &nbsp; 编程环境安装
</a>
</li>
<li class="md-nav__item">
<a href="../../chapter_appendix/contribution/" class="md-nav__link">
13.2. &nbsp; 一起参与创作
<a href="../../chapter_backtracking/backtracking_algorithm/" class="md-nav__link">
13.1. &nbsp; 回溯算法New
</a>
</li>
@@ -1806,6 +1758,77 @@
<label class="md-nav__link" for="__nav_15" id="__nav_15_label" tabindex="0">
14. &nbsp; &nbsp; 附录
<span class="md-nav__icon md-icon"></span>
</label>
<nav class="md-nav" data-md-level="1" aria-labelledby="__nav_15_label" aria-expanded="false">
<label class="md-nav__title" for="__nav_15">
<span class="md-nav__icon md-icon"></span>
14. &nbsp; &nbsp; 附录
</label>
<ul class="md-nav__list" data-md-scrollfix>
<li class="md-nav__item">
<a href="../../chapter_appendix/installation/" class="md-nav__link">
14.1. &nbsp; 编程环境安装
</a>
</li>
<li class="md-nav__item">
<a href="../../chapter_appendix/contribution/" class="md-nav__link">
14.2. &nbsp; 一起参与创作
</a>
</li>
</ul>
</nav>
</li>
<li class="md-nav__item md-nav__item--section md-nav__item--nested">
<input class="md-nav__toggle md-toggle " type="checkbox" id="__nav_16" >
@@ -1818,8 +1841,8 @@
</div>
<nav class="md-nav" data-md-level="1" aria-labelledby="__nav_15_label" aria-expanded="false">
<label class="md-nav__title" for="__nav_15">
<nav class="md-nav" data-md-level="1" aria-labelledby="__nav_16_label" aria-expanded="false">
<label class="md-nav__title" for="__nav_16">
<span class="md-nav__icon md-icon"></span>
参考文献
</label>
@@ -1860,11 +1883,11 @@
<ul class="md-nav__list" data-md-component="toc" data-md-scrollfix>
<li class="md-nav__item">
<a href="#741-avl" class="md-nav__link">
7.4.1. &nbsp; AVL 树常见术语
<a href="#841-avl" class="md-nav__link">
8.4.1. &nbsp; AVL 树常见术语
</a>
<nav class="md-nav" aria-label="7.4.1. &nbsp; AVL 树常见术语">
<nav class="md-nav" aria-label="8.4.1. &nbsp; AVL 树常见术语">
<ul class="md-nav__list">
<li class="md-nav__item">
@@ -1887,11 +1910,11 @@
</li>
<li class="md-nav__item">
<a href="#742-avl" class="md-nav__link">
7.4.2. &nbsp; AVL 树旋转
<a href="#842-avl" class="md-nav__link">
8.4.2. &nbsp; AVL 树旋转
</a>
<nav class="md-nav" aria-label="7.4.2. &nbsp; AVL 树旋转">
<nav class="md-nav" aria-label="8.4.2. &nbsp; AVL 树旋转">
<ul class="md-nav__list">
<li class="md-nav__item">
@@ -1935,11 +1958,11 @@
</li>
<li class="md-nav__item">
<a href="#743-avl" class="md-nav__link">
7.4.3. &nbsp; AVL 树常用操作
<a href="#843-avl" class="md-nav__link">
8.4.3. &nbsp; AVL 树常用操作
</a>
<nav class="md-nav" aria-label="7.4.3. &nbsp; AVL 树常用操作">
<nav class="md-nav" aria-label="8.4.3. &nbsp; AVL 树常用操作">
<ul class="md-nav__list">
<li class="md-nav__item">
@@ -1969,8 +1992,8 @@
</li>
<li class="md-nav__item">
<a href="#744-avl" class="md-nav__link">
7.4.4. &nbsp; AVL 树典型应用
<a href="#844-avl" class="md-nav__link">
8.4.4. &nbsp; AVL 树典型应用
</a>
</li>
@@ -1998,7 +2021,7 @@
<h1 id="74-avl">7.4. &nbsp; AVL 树 *<a class="headerlink" href="#74-avl" title="Permanent link">&para;</a></h1>
<h1 id="84-avl">8.4. &nbsp; AVL 树 *<a class="headerlink" href="#84-avl" title="Permanent link">&para;</a></h1>
<p>在二叉搜索树章节中,我们提到了在多次插入和删除操作后,二叉搜索树可能退化为链表。这种情况下,所有操作的时间复杂度将从 <span class="arithmatex">\(O(\log n)\)</span> 恶化为 <span class="arithmatex">\(O(n)\)</span></p>
<p>如下图所示,经过两次删除节点操作,这个二叉搜索树便会退化为链表。</p>
<p><img alt="AVL 树在删除节点后发生退化" src="../avl_tree.assets/avltree_degradation_from_removing_node.png" /></p>
@@ -2009,7 +2032,7 @@
<p align="center"> Fig. AVL 树在插入节点后发生退化 </p>
<p>G. M. Adelson-Velsky 和 E. M. Landis 在其 1962 年发表的论文 "An algorithm for the organization of information" 中提出了「AVL 树」。论文中详细描述了一系列操作确保在持续添加和删除节点后AVL 树不会退化,从而使得各种操作的时间复杂度保持在 <span class="arithmatex">\(O(\log n)\)</span> 级别。换句话说在需要频繁进行增删查改操作的场景中AVL 树能始终保持高效的数据操作性能,具有很好的应用价值。</p>
<h2 id="741-avl">7.4.1. &nbsp; AVL 树常见术语<a class="headerlink" href="#741-avl" title="Permanent link">&para;</a></h2>
<h2 id="841-avl">8.4.1. &nbsp; AVL 树常见术语<a class="headerlink" href="#841-avl" title="Permanent link">&para;</a></h2>
<p>「AVL 树」既是二叉搜索树也是平衡二叉树,同时满足这两类二叉树的所有性质,因此也被称为「平衡二叉搜索树」。</p>
<h3 id="_1">节点高度<a class="headerlink" href="#_1" title="Permanent link">&para;</a></h3>
<p>在操作 AVL 树时,我们需要获取节点的高度,因此需要为 AVL 树的节点类添加 <code>height</code> 变量。</p>
@@ -2382,7 +2405,7 @@
<p class="admonition-title">Note</p>
<p>设平衡因子为 <span class="arithmatex">\(f\)</span> ,则一棵 AVL 树的任意节点的平衡因子皆满足 <span class="arithmatex">\(-1 \le f \le 1\)</span></p>
</div>
<h2 id="742-avl">7.4.2. &nbsp; AVL 树旋转<a class="headerlink" href="#742-avl" title="Permanent link">&para;</a></h2>
<h2 id="842-avl">8.4.2. &nbsp; AVL 树旋转<a class="headerlink" href="#842-avl" title="Permanent link">&para;</a></h2>
<p>AVL 树的特点在于「旋转 Rotation」操作它能够在不影响二叉树的中序遍历序列的前提下使失衡节点重新恢复平衡。换句话说<strong>旋转操作既能保持树的「二叉搜索树」属性,也能使树重新变为「平衡二叉树」</strong></p>
<p>我们将平衡因子绝对值 <span class="arithmatex">\(&gt; 1\)</span> 的节点称为「失衡节点」。根据节点失衡情况的不同,旋转操作分为四种:右旋、左旋、先右旋后左旋、先左旋后右旋。下面我们将详细介绍这些旋转操作。</p>
<h3 id="_3">右旋<a class="headerlink" href="#_3" title="Permanent link">&para;</a></h3>
@@ -3073,7 +3096,7 @@
</div>
</div>
</div>
<h2 id="743-avl">7.4.3. &nbsp; AVL 树常用操作<a class="headerlink" href="#743-avl" title="Permanent link">&para;</a></h2>
<h2 id="843-avl">8.4.3. &nbsp; AVL 树常用操作<a class="headerlink" href="#843-avl" title="Permanent link">&para;</a></h2>
<h3 id="_8">插入节点<a class="headerlink" href="#_8" title="Permanent link">&para;</a></h3>
<p>「AVL 树」的节点插入操作与「二叉搜索树」在主体上类似。唯一的区别在于,在 AVL 树中插入节点后,从该节点到根节点的路径上可能会出现一系列失衡节点。因此,<strong>我们需要从这个节点开始,自底向上执行旋转操作,使所有失衡节点恢复平衡</strong></p>
<div class="tabbed-set tabbed-alternate" data-tabs="8:10"><input checked="checked" id="__tabbed_8_1" name="__tabbed_8" type="radio" /><input id="__tabbed_8_2" name="__tabbed_8" type="radio" /><input id="__tabbed_8_3" name="__tabbed_8" type="radio" /><input id="__tabbed_8_4" name="__tabbed_8" type="radio" /><input id="__tabbed_8_5" name="__tabbed_8" type="radio" /><input id="__tabbed_8_6" name="__tabbed_8" type="radio" /><input id="__tabbed_8_7" name="__tabbed_8" type="radio" /><input id="__tabbed_8_8" name="__tabbed_8" type="radio" /><input id="__tabbed_8_9" name="__tabbed_8" type="radio" /><input id="__tabbed_8_10" name="__tabbed_8" type="radio" /><div class="tabbed-labels"><label for="__tabbed_8_1">Java</label><label for="__tabbed_8_2">C++</label><label for="__tabbed_8_3">Python</label><label for="__tabbed_8_4">Go</label><label for="__tabbed_8_5">JavaScript</label><label for="__tabbed_8_6">TypeScript</label><label for="__tabbed_8_7">C</label><label for="__tabbed_8_8">C#</label><label for="__tabbed_8_9">Swift</label><label for="__tabbed_8_10">Zig</label></div>
@@ -3723,7 +3746,7 @@
</div>
<h3 id="_10">查找节点<a class="headerlink" href="#_10" title="Permanent link">&para;</a></h3>
<p>AVL 树的节点查找操作与二叉搜索树一致,在此不再赘述。</p>
<h2 id="744-avl">7.4.4. &nbsp; AVL 树典型应用<a class="headerlink" href="#744-avl" title="Permanent link">&para;</a></h2>
<h2 id="844-avl">8.4.4. &nbsp; AVL 树典型应用<a class="headerlink" href="#844-avl" title="Permanent link">&para;</a></h2>
<ul>
<li>组织和存储大型数据,适用于高频查找、低频增删的场景;</li>
<li>用于构建数据库中的索引系统;</li>
@@ -3809,7 +3832,7 @@
<nav class="md-footer__inner md-grid" aria-label="页脚" >
<a href="../binary_search_tree/" class="md-footer__link md-footer__link--prev" aria-label="上一页: 7.3. &amp;nbsp; 二叉搜索树" rel="prev">
<a href="../binary_search_tree/" class="md-footer__link md-footer__link--prev" aria-label="上一页: 8.3. &amp;nbsp; 二叉搜索树" rel="prev">
<div class="md-footer__button md-icon">
<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path d="M20 11v2H8l5.5 5.5-1.42 1.42L4.16 12l7.92-7.92L13.5 5.5 8 11h12Z"/></svg>
</div>
@@ -3818,20 +3841,20 @@
上一页
</span>
<div class="md-ellipsis">
7.3. &nbsp; 二叉搜索树
8.3. &nbsp; 二叉搜索树
</div>
</div>
</a>
<a href="../summary/" class="md-footer__link md-footer__link--next" aria-label="下一页: 7.5. &amp;nbsp; 小结" rel="next">
<a href="../summary/" class="md-footer__link md-footer__link--next" aria-label="下一页: 8.5. &amp;nbsp; 小结" rel="next">
<div class="md-footer__title">
<span class="md-footer__direction">
下一页
</span>
<div class="md-ellipsis">
7.5. &nbsp; 小结
8.5. &nbsp; 小结
</div>
</div>
<div class="md-footer__button md-icon">