昨天我们介绍了在进行结点插入时,若左子树深度超过右子树深度两层则进行右旋来保持平衡。今天继续介绍,若右子树深度超过左子树深度两层时的左旋操作,以及删除结点后平衡因子的变更问题。

这些都掌握后,基本上对AVL就有一个很全面的认知了。除了利用平衡因子来解决BST的平衡问题,我们还可以利用结点颜色,设定规则来解决BST的平衡问题,后面我们会介绍另一种更加有效的算法–红黑树。希望大家能够掌握,作为自己的武器来探索我们的未知……











算法基础知识科普:8大搜索算法之AVL树(下)相关推荐

  1. 算法基础知识科普:8大搜索算法之二叉搜索树(下)

    由于微信发代码以及数学符号很吃力,所以我们做知识科普只能利用图片来做,本算法代码较多,所以分为三个部分来介绍.本篇把剩余的部分补齐.当然二叉搜索树也有自己的缺陷,即构造的二叉树跟数据的初始状态以及删除 ...

  2. 算法基础知识科普:8大搜索算法之红黑树(下)

    这是介绍红黑树的最后一部分,令y为要删除结点,n为要删除结点的子结点(子结点最多有1个),w为y的兄弟结点,删除操作的重点是使红黑树删除结点并通过调整后仍满足自身是搜索二叉树和设定的三点规则.删除操作 ...

  3. 算法基础知识科普:8大搜索算法之顺序搜索

    基本概念和术语 搜索表(Search Table):是由同一类型的数据元素(或记录)构成的集合. 关键字(Key):是数据元素中某个数据项的值,用它可以标识一个数据元素.若此关键字可以唯一地标识一个记 ...

  4. 算法基础知识科普:8大搜索算法之红黑树(上)

    平衡二叉树(AVL)是一种特殊的二叉搜索树(BST),即每个结点的值都大于其左子树且小于其右子树的值(若存在),并通过引入平衡因子的概念来保持树的平衡.平衡二叉树算法的重点是在插入.删除结点时,如何保 ...

  5. 算法基础知识科普:8大搜索算法之AVL树(中)

    昨天我们介绍了平衡二叉树的基本概念,通过平衡因子来控制左右子树的深度,使得整个二叉搜索树始终保持平衡状态.这个算法的核心在于当平衡因子超过范围,如何通过旋转的方式来使二叉搜索树保持平衡,以及平衡后对应 ...

  6. 算法基础知识科普:8大搜索算法之二叉搜索树(中)

    昨天图文介绍了二叉搜索树的基本概念,本篇图文介绍二叉搜索树的具体实现.既然二叉搜索树是二叉树的特殊应用,所以我们首先封装二叉树的结点,即数据-左子树-右子树,然后实现ISymbolTalbe接口中的方 ...

  7. 算法基础知识科普:8大搜索算法之二叉搜索树(上)

    前几天,我们介绍了在顺序存储结构上构建的搜索算法,如二分搜素,插补搜索等,这种结构适合于静态搜索,但对于动态搜索会涉及到大量记录的移动导致效率的降低.这样我们自然会想是否能够利用链式的存储结构,这样在 ...

  8. 算法基础知识科普:8大搜索算法之二分搜索

    昨天介绍了对无序搜素表的顺序搜索方法,今天介绍对有序搜索表的二分搜索方法,"二分"在算法设计中是非常常用的一种思想,除了处理如下普通的搜索外,还用于搜索方程的解等工程领域.但二分法 ...

  9. 算法基础知识科普:8大搜索算法之红黑树(中)

    红黑树也是一种特殊形式的二叉搜索树,通过结点的颜色以及三条规则来保证二叉搜索树的平衡.规则1:根结点的颜色是黑色,规则2:叶子结点到根结点路径上遇到的黑色结点数目相同,规则3:叶子结点到根结点路径上无 ...

最新文章

  1. linux日志怎么进行转储,Linux logrotate命令用法详解:进行日志转储(轮替)
  2. 在系统中使用read函数读取文件内容
  3. mysql笔记一——安装和设置root密码
  4. CodeForces-1058B B. Vasya and Cornfield
  5. 统计 python_Python统计简介
  6. Linux存储保护,谈谈Linux中的存储保护
  7. 【ES11(2020)】Promise 扩展 allSettled()
  8. Nest,很酷的东西
  9. 怎么画六面体网格_使用Abaqus完成网格重划分分析3网格到网格的解映射
  10. andoid-sdk 安装时出现 Stopping ADB server failed(code -1) 错
  11. 【VB.Net】泛型IIF
  12. 即时语音提示软件php,即时语音提示校对专家
  13. ArcGIS地理配准、影像校正步骤
  14. supersu二进制更新安装失败_supersu 二进制更新解决方法
  15. 任正非《一江春水向东流》读后感
  16. 树莓派内网穿透及其实现监控的相关整理
  17. c语言分离个位十位百位_用c语言如何表示出一个数的个位,百位,十位
  18. ADO 从ACCESS数据库读取图片并显示出来
  19. mini2440+阿里云+Qt/android 打造智能音箱
  20. 工业现场云解决方案的设计与实践

热门文章

  1. 初识软件体系结构(1-4课时)
  2. 参加软件测试培训前景怎么样
  3. UI设计培训分享:平面广告设计中的文案表达技巧
  4. 什么是Python?好学吗?
  5. Python培训教程:Python内置数据结构之双向队列
  6. 学Python的好处有哪些?
  7. ubuntu 12 JDK 编译
  8. 排序算法总结之堆排序
  9. 让你的网站支持 Emoji
  10. SNMP 协议 OID的使用