关于AVL树的插入,其实是一个比较复杂的问题,主要是在于他对于“旋转”这一概念,对于这一概念其实我感觉很多博主讲的都不是很明白,包括CHATGPT,也试了,但是也没有比较清楚的解释,他们主要集中在一种比较简单的情况,即没有任何子树的情况,如下所示





对于这种最基本的平衡维护,确实不是一件困难的事情,这个可以作为一种技巧,来帮助我们快速的来去得到答案。所以在这里,我会先从最基本的情况来去讲解这里是怎么个操作的流程,这里会不用“旋转”这一概念来解释平衡的维护,而是一种更加简单易懂的方式来讲解。

(注  本次的博客会在发布之后补充上代码,现在不会添加代码,只是会提供相关的概念)

其实个人觉得看到不错的是这个,推荐一下便于大家学习https://www.hello-algo.com/chapter_tree/avl_tree/#2_1

OK。可恶的作者终于把他的废话说完了,现在开始要说内容了。

首先是对于这里的基本情况。

如下所示



可以看到是有四种情况,这里即是插入节点后失衡的四种情况。对于这四种情况,我们可以对他们做一个分类,分为直线型和弯线型。

为什么叫直线型和弯线型,其实在这里是非常明显的(这里当然很明显,但是对于实际的节点插入来说就不是特别明显了),我们将插入的节点向上回溯,然后一直到第一个失衡点,这样子来看,到达第一个失衡点之后,向下往插入点的方向标记三个单位,这个三个点就是接下来要主要操作的三个点了。

如下所示,



可以看到如上面的图片所示,可以知道,他为什么叫直线型和弯线型。那么接下来,就是如何对他们做操作呢,其实也是很简单的。

对于直线型,我们要做的就是把他掰弯,为了方便起见,我们将这三个点由上到下分别叫做爷爷,父亲,儿子。那么要做的是把爷爷弯折至和儿子一个高度,让后再将父亲给连接上。

对于弯线型,则是不一样,我们要先将它弄直,然后再像直线型一样操作。对于再将弯线型弄直的过程中,由于他是一个二叉树,所以要将父亲和儿子的值给交换一下,这样子才可以让其维持二叉树的特点。

那么这种最基本的情况讲完了,但是这并不足以应付一些复杂的情况,如果说存在子树的话,那么怎么去移动父亲,儿子,爷爷三个点的子树就成为了问题。

那么如下所示



对于这样子一个二叉树,我应该怎么去维护他的平衡性。可以按照如下的操作。

首先我们要先找到他的不平衡点,我们去依次标记他的子树的大小,如下所示



可以知道当前的为直线型,爷爷,父亲,儿子分别为4,7,15三个点,那么由于是直线型,那么父亲必然是要作为接下来的新根节点,但是问题是此时,由于他是在中间位置,如果我直接去做弯折的操作,就会导致他的子树无法处理(总不能直接变成三叉树吧),所以这个时候,我需要做的是对他的子树进行转移。

如何转移他的子树呢,对于由于此时爷爷节点在下移了之后,他的位置有一个子树的位置是空了,所以在这里可以把子树转移到他的爷爷节点下面,转移之后,如下所示



实际上,我们就是将节点转移到了爷爷上面,并且把父亲作为了新的根节点。

那么对于有子树的弯折型,又应该怎么处理呢,可以参考如下的例子。在这里,已经标记好了弯折点。



在这里,接下来要做的就是去首先将它给掰直,在掰直的过程中,可以发现由于16的存在,影响了掰直,所以在这里的处理措施是将将7移动到与6连接的地方,在这之后,就是将15节点移动下来,并将14节点拼接到15节点上,这样,就完成了一次移动,完成后的结果如下所示。

之后,我们可以看到他接下来就可以弄弯了。



这样子,我们就可以实现对他的平衡的维护了。

最后总结一下吧。

1.对于直线型,我们要做的是将它儿子的那个不在线上的子树给他的父亲节点,这样子就可以完成平衡的维护

2.对于弯线型,则可以去将其儿子的子树给到父亲节点,然后将儿子放在中间位置,在这之后,就是做和直线型一样的操作。

AVL树的插入的更多相关文章

  1. AVL树的插入操作(旋转)图解

    =================================================================== AVL树的概念       在说AVL树的概念之前,我们需要清楚 ...

  2. AVL 树的插入、删除、旋转归纳

    参考链接: http://blog.csdn.net/gabriel1026/article/details/6311339   1126号注:先前有一个概念搞混了: 节点的深度 Depth 是指从根 ...

  3. AVL树的插入和删除

    一.AVL 树 在计算机科学中,AVL树是最早被发明的自平衡二叉查找树.在AVL树中,任一节点对应的两棵子树的最大高度差为 1,因此它也被称为高度平衡树.查找.插入和删除在平均和最坏情况下的时间复杂度 ...

  4. 【动画笔记】数据结构-AVL树的插入操作

    本笔记前置知识: 二叉搜索(排序)树及其插入操作. 本文主要围绕AVL树的平衡因子.纸上做题思路.失衡类型(LL/RR/LR/RL).失衡调整方法.插入后回溯这几部分知识点展开. 注: 本笔记中的平衡 ...

  5. AVL树的插入删除查找算法实现和分析-1

    至于什么是AVL树和AVL树的一些概念问题在这里就不多说了,下面是我写的代码,里面的注释非常详细地说明了实现的思想和方法. 因为在操作时真正需要的是子树高度的差,所以这里采用-1,0,1来表示左子树和 ...

  6. AVL树的插入与删除

    AVL 树要在插入和删除结点后保持平衡,旋转操作必不可少.关键是理解什么时候应该左旋.右旋和双旋.在Youtube上看到一位老师的视频对这个概念讲解得非常清楚,再结合算法书和网络的博文,记录如下. 1 ...

  7. 第七章 二叉搜索树 (d2)AVL树:插入

  8. 创建AVL树,插入,删除,输出Kth Min

    https://github.com/TouwaErioH/subjects/tree/master/C%2B%2B/PA2 没有考虑重复键,可以在结构体内加一个int times. 没有考虑删除不存 ...

  9. 二叉查找树(BST)、平衡二叉树(AVL树)(只有插入说明)

    二叉查找树(BST).平衡二叉树(AVL树)(只有插入说明) 二叉查找树(BST) 特殊的二叉树,又称为排序二叉树.二叉搜索树.二叉排序树. 二叉查找树实际上是数据域有序的二叉树,即对树上的每个结点, ...

  10. 数据结构--Avl树的创建,插入的递归版本和非递归版本,删除等操作

    AVL树本质上还是一棵二叉搜索树,它的特点是: 1.本身首先是一棵二叉搜索树.   2.带有平衡条件:每个结点的左右子树的高度之差的绝对值最多为1(空树的高度为-1).   也就是说,AVL树,本质上 ...

随机推荐

  1. Linux Shell_read

    介绍 从控制台输入 基本语法 read [选项] 参数 常用选项 |选项|功能| |-|-| |-p|指定读取值时的提示符| |-t|指定取值时等待的时间(秒),如果没有在指定时间输入,就不再等待了| ...

  2. Rsync远程同步知识点总结

    Rsync: 简介:是一个开源的快速备份工具.可以在不同主机之间镜像同步整个目录,支持增量备份,保持链接(硬链接.软连接)和权限,且采用优化同步算法,传输前执行压缩(传输过程中效率加快了,但是会增加c ...

  3. ubuntu系统安装wps后语言是英文的问题

    如果安装ubuntu系统后,在里面安装wps的时候,发现都是英文,无法切换为中文,可以这样操作. 此时点击这里新建一个word空白文档 点击这里新建文档 点击这里显示语言 点击下面的 简体中文 再点击 ...

  4. Nuxt.js 应用中的 webpack:compiled 事件钩子

    title: Nuxt.js 应用中的 webpack:compiled 事件钩子 date: 2024/11/23 updated: 2024/11/23 author: cmdragon exce ...

  5. SQL排序分组

    --按某一字段分组取最大(小)值所在行的数据(2007-10-23于浙江杭州) /* 数据如下: name val memo a 2 a2(a的第二个值) a 1 a1--a的第一个值 a 3 a3: ...

  6. Java方法参数太多怎么办—Part 1—自定义类型

    本文由 ImportNew - 王村平 翻译自 dzone.如需转载本文,请先参见文章末尾处的转载要求. 本文是这个系列的第一篇文章,介绍了采用自定义类型处理参数过多的问题.如果你也希望参与类似的系列 ...

  7. Displaying XML in a Swing JTree

    Overview It seems obvious enough: You have an XML document or fragment. XML is hierarchical. A Swing ...

  8. Lnmp编译安装(2020)

    之前写过几篇有关安装lnmp环境的文章,现在回顾感觉有些比较老了或者并不是好的操作,于是更新这篇 1. 安装Nginx 1) 依赖安装 yum install gcc gcc-c++ openssl ...

  9. Element-ui 表单嵌套验证

    1.当表单的字段值是数组或者对象时的rules配置 对象:直接用obj.xx配置rules和prop 数组:用list.index.xx配置rules和prop <el-form :model= ...

  10. 指针, C语言的精髓

    指针, C语言的精髓 莫队先咕几天, 容我先讲完树剖 (因为后面树上的东西好多都要用树剖求 LCA). 什么是指针 保存变量地址的变量叫做指针. 这是大概的定义, 但是Defad认为这个定义不太好理解 ...