树之设计【AVL树、红黑树的设计】

技术树之设计【AVL树、红黑树的设计】 树之设计【AVL树、红黑树的设计】树之设计【AVL树、红黑树的设计】1,设计之初:? 思考:AVL树的意义:高度平衡二叉树,用来维持整棵树是一棵平衡的二叉树,那么

树形设计【AVL树,红黑树设计】。

树之设计【AVL树、红黑树的设计】

1,设计之初:

?思考:AVL树的意义:用一个高度平衡的二叉树来维持整棵树为一个平衡的二叉树,所以在继承父类[BST二叉查找树]的基础上,考虑AVL什么时候需要调整它的平衡。

 --------------------------------------BST 二叉搜索树,进行插入(增加)结点之后的树,可能失衡,需要调整。

   -------------------而调整树的主要工作,应该交由AVL 平衡二叉树来完成

【 过程:BST (内部知道发生了失衡,所以需要做出反应),它定义了一个接口方法(调整平衡方法)来应对失衡情况,这个调整平衡方法,交由能力最强的AVL树去具体实现】

接下来,我们来谈谈调整平衡法的具体实现:

1.首先从插入节点的位置开始,找到第一个不平衡的祖父母节点【这个过程需要判断节点不平衡】-需要节点高度属性。

-

-解决方案:AVL树【此刻需要有一个带有高度属性的节点类】重构节点类,添加高度属性。

2.重构后,回到BST中插入(添加)接口的方法:发现该方法的内部创建结点时,使用的结点对象都是通用的结点,并没有使用 AVL 树定义的结点类对象,小于高度属性。

回到AVL树,在AVL树中无法高度判断是否失衡。

--解决:在BST中定义一个创建结点接口方法(默认:创建的节点是公共节点),然后子类 AVL 树再对创建结点接口方法进行重写,

因此,当您需要在添加(插入)接口的方法中创建节点时,您可以使用创建出带有高度属性的结点对象。.

2,设计过程:

内容来源网络,如有侵权,联系删除,本文地址:https://www.230890.com/zhan/51631.html

(0)

相关推荐

  • LeetCode刷题之DP算法

    技术LeetCode刷题之DP算法 LeetCode刷题之DP算法LeetCode刷题之动态规划算法
    1.基本思路及代码框架
    首先,动态规划的穷举有点特别,因为这类问题存在「重叠子问题」,如果暴力穷举的

    礼包 2021年11月29日
  • java的定义类如何使用(java怎么定义实现类)

    技术Java的组合类怎么定义这篇文章主要讲解了“Java的组合类怎么定义”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Java的组合类怎么定义”吧!我们可以在一个新类的定

    攻略 2021年12月21日
  • 如何使用Ant进行ssh和scp操作

    技术如何使用Ant进行ssh和scp操作今天就跟大家聊聊有关如何使用Ant进行ssh和scp操作,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。使用Ant进行ssh

    攻略 2021年11月10日
  • mysqlhotcopy备份报错该怎么解决

    技术mysqlhotcopy备份报错该怎么解决mysqlhotcopy备份报错该怎么解决,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。问题:

    攻略 2021年12月4日
  • 如何使用Ngrok将局域网服务映射到公网

    技术如何使用Ngrok将局域网服务映射到公网本篇文章给大家分享的是有关如何使用Ngrok将局域网服务映射到公网,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。

    攻略 2021年11月10日
  • 中国十大名牌大学排名,中国十大名牌大学是哪十所

    技术中国十大名牌大学排名,中国十大名牌大学是哪十所根据2018最新中国双一流大学排名中国十大名牌大学排名,前十所大学分别是:北京大学清华大学
    浙江大学
    复旦大学
    中国人民大学
    上海交通大学
    武汉大学
    南京大学
    中山大学

    生活 2021年10月31日