树之设计【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)

相关推荐

  • 抖音刷人气软件免费,选择优质的刷赞平台

    技术抖音刷人气软件免费,选择优质的刷赞平台抖音的粉丝在哪儿买?怎样可以增加抖音的点赞和粉丝?现在很多人都喜欢抖音短视频,这段时间里,抖音很火,抖音挑战赛开始后,参与人数很多。每个人都在想如何才能拍出高质量的视频,观看量,

    2021年10月20日
  • Java的三大版本有什么区别

    技术Java的三大版本有什么区别这篇文章主要介绍“Java的三大版本有什么区别”,在日常操作中,相信很多人在Java的三大版本有什么区别问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”Jav

    攻略 2021年11月24日
  • 字母顺序,bpmf拼音26个字母顺序

    技术字母顺序,bpmf拼音26个字母顺序声母 b p m f d t n l g k h j q x zh ch sh r z c s y w 韵母 a o

    生活 2021年10月23日
  • 使用awk比较两个文件的内容

    技术使用awk比较两个文件的内容 使用awk比较两个文件的内容干货记录
    [Linux] 使用awk比较两个文件的内容
    当需要比较A , B两个文件 , A文件中存在 , 并且把也在B文件中存在的行去除掉

    礼包 2021年11月20日
  • 以读书为话题的作文600字,以我爱阅读经典文学为主题的作文

    技术以读书为话题的作文600字,以我爱阅读经典文学为主题的作文初中一年级的时候以读书为话题的作文600字,曾害过一场病,父亲听从医生劝嘱,让我休学一年。当时为这我还哭过好 一阵子鼻子,休学,就意味着学业上掉队,但我终究没

    生活 2021年10月27日
  • 鲁滨逊是什么样的人,鲁滨逊是一个怎样的人?举例说明

    技术鲁滨逊是什么样的人,鲁滨逊是一个怎样的人?举例说明鲁滨逊漂流记》 鲁滨逊这个人物是世界文学中第一个资产阶级正面典型.他出生于一个有着幸福生活的中产阶层生活的家庭,原本他可以安乐地过完一生,可是从小便想遨游四海的念头促

    生活 2021年10月25日