当前位置:网站首页>015-Balanced binary tree (1)
015-Balanced binary tree (1)
2022-08-03 09:03:00 【51CTO】
1)、LL:LeftLeft,也称为"左左".插入或删除一个节点后,根节点的左子树的左子树还有非空子节点,导致"根的左子树的高度"比"根的右子树的高度"大2,导致AVL树失去了平衡.
例如,在下面LL情况中,由于"根节点(10)的左子树(5)的左子树(4)还有非空子节点",而"根节点(10)的右子树(20)没有子节点";导致"根节点(10)的左子树(5)高度"比"根节点(10)的右子树(20)"高2.
The rotation of the solution to the diagram below:
对于(10)The left subtree is(5)Or may not have the right sub tree(6).So what are the specific process from left to right?
对于(5)号有:Father node needs to change;The right subtree need to change.
对于(10)号有:Father node needs to change;The left subtree need to change.
对于(6)号有:Father node needs to change.
Another highly need to adjust.
具体过程是:第一,先保存(5)号节点;第二,截断(5)No right subtree(6)给(10)The left subtree is;第三,将(10)号作为(5)No right subtree.
左左情况:一是:左左左,The second is left around.In both cases can merge processing,And deal with exactly the same as above.
2、左右情况.One is about the left,The second is about right.
3、RR的情况.
4、右左情况:One is the right left left,The second is right about.The following are the first、第二种情况,Can merge.
The third tree below has a place to draw the wrong,节点45应该是节点20的右孩子,As the node and the picture50的左孩子了.
代码分析:节点信息如下:其中parentMembers are redundant,可以去掉.
思路:Recursively find insertion point,并插入节点.The way back to the root node in the process of judging the recursive all the nodes in the path difference in height between the left and right subtrees if2,If reach the adjustment according to the type,And update all the nodes in the path of high.
LL旋转代码如下:
一、思想:分类讨论
二、Binary search tree delete specific discussion in the following four conditions:(Remember we are trying to remove node asD)
1、如果DNeither left child node,也没有右孩子,那么直接删除就好了;
2、如果D节点只有左孩子,没有右孩子,Then only need to take theDLeft child node link toD节点的父亲节点,然后删除D节点就好了;
3、如果D节点只有右孩子,没有左孩子,Then only need to take theDRight child node link toD节点的父亲节点,然后删除D节点就好了;
4、如果D节点既有左孩子,又有右孩子,那么需要找到DNode of the right subtree of the minimum node,After finding directly replaceD节点,Then delete the find the minimum value of node.(解释:因为DNode node has about two children,很显然DAll the nodes in a node in the left subtree are less thanD节点的值,DAll the nodes in a node of the right subtree of value is greater thanD节点的值,This is based on the definition of binary search trees get the conclusion that.那么现在D要被删除,那么DDeleted after who can replace the position?显然只能是DThe right subtree of the minimum can play,Because it satisfies more thanDAll the nodes in a node in the left subtree value,因为DAll right subtree node values greater thanDThe left subtree of node value;At the same time also meet less thanDAll other nodes in the right subtree of value,因为DThe lowest value in a subtree is right,当然小于DThe right of all other nodes in the subtree value)
三、图例说明:
1、第一种情况:This kind of situation is actually a leaf node delete,Anyway it girls,Delete the delete,He is not much more,少它不少.Such as delete image below21号元素,It doesn't have the left child,也没有右孩子,Directly to its parent to its link to delete the line.
2、第二种情况:删除10号节点,该节点只有左孩子,没有右孩子.只需要三步即可,删除10No node point to its5No left subtree link,删除10号节点的父节点15No links to her,将10号节点的父节点15No link to the left10号的5The left subtree is.
3、第三种情况:删除40号节点,该节点只有右孩子,没有左孩子.只需要三步即可,删除40No node point to its50No right subtree link,删除40号节点的父节点30No links to her,将40号节点的父节点30No link to the right40号的50No right subtree.
4、第四种情况:删除20号节点,Because he has left child,又有右孩子.所以先找到20Node number of the lowest value of all the nodes in the right subtree is as21号,Actually right subtree of the minimum value is in the right subtree of the leftmost that node;找到替换节点21No. You can proceed to the next step operation,如下图,20Number to the parent node of links to the change to point to the21号,20About the child links also need to be replaced,21Number of the original parent node to remove.
当然了,You can also find out30Left all the nodes in a subtree of the number of maximum value to replace the20号节点.方法差不多,要替换一个节点,Went to the most close to his left subtree nodes,Or the most close to him to his right subtree of a node,Is the precursor of nodes and node displacement after.
Need to understand the two concepts in here,叫“前驱”和“后继”.Respectively in the tree are less than its maximum and is more than its minimum value,If all the nodes in a tree structure according to order a good,Its precursor and its subsequent just two nodes in its left and right next to it.当一个节点被删除时,In order to ensure no damage to the structure of binary tree,To make its precursors or subsequent nodes to replace its position,Then its precursors or subsequent nodes also do delete.
So how to find precursors or subsequent.小于它的最大值,Is in the tree the most right in its left subtree of that node.同样,Is greater than its minimum value,The most on the left is in its right subtree of that node.When a node when there are both left child node and right child nodes,Precursor is its left child node's right child node's right child node...Until the right child node;Following is the right child node's left child node's left child node...Until the left child node.
边栏推荐
- 浅析什么是伪类和伪元素?伪类和伪元素的区别解析
- 分析型数据库性能测试总结
- 【LeetCode】226. Flip the binary tree
- WPS EXCEL 筛选指定长度的文本 内容 字符串
- WPF 学习笔记《WPF样式基础》
- STP生成树(端口状态+端口角色+收敛机制 )|||| STP优化技术( uplinkfast技术+Portfast技术+backbonefast技术 )详解
- 阿里云·短信发送
- dflow部署简记
- STP普通生成树安全特性— bpduguard特性 + bpdufilter特性 + guard root 特性 III loopguard技术( 详解+配置)
- MySQL-DDL数据定义语言-约束
猜你喜欢
随机推荐
FusionAccess软件架构、FusionAccess必须配置的四个组件、桌面发放流程、虚拟机组类型、桌面组类型
【LeetCode】112.路径总和
行业洞察 | 如何更好的实现与虚拟人的互动体验?
文章列表的显示 以及创建文章 还有文章详情的基本
多媒体数据处理实验1:算术编码
删除文件夹时,报错“错误ox80070091:目录不是空的”,该如何解决?
英文语法-状语从句
【LeetCode】622. Design Circular Queue
Exception: Dataset not found. Solution
长短期记忆网络 LSTM
MySQL-TCL语言-transaction control language事务控制语言
并发之ReentrantLock
ArcEngine (3) zoom in and zoom out through the MapControl control to achieve full-image roaming
Laya中关于摄像机跟随人物移动或者点击人物碰撞器触发事件的Demo
English Grammar - Adverbial Clauses
牛客 - 最佳直播时间 (差分)
QImage的指针问题
【TPC-DS】DF的SQL(Data Maintenance部分)
CSP-S2019 Day2
QT中线程调用GUI主线程控件的问题