搞懂平衡二叉树的左旋右旋双旋(Java实现)

article/2025/9/29 5:57:14

刚看到韩顺平老师的数据结构与算法对于平衡二叉树的讲解(最后会附上地址),有如下理解,希望能帮助大家!哪里需要改正的欢迎指正!

平衡二叉树:一种二叉排序树(BST Binary Sort Tree)的升级,传统的二叉排序树容易形成类似链表的结构,造成平均查询次数较高,所以引入平衡二叉树,使得左右子树的高度差不超过1;
在这里插入图片描述我们知道了平衡二叉树的原理之后,就要在添加结点后就要判断是否需要将此树转化成平衡二叉树!如下例:4,3,5,2,1,0
在这里插入图片描述如图,当添加到1这个结点的时候,4的左子树高为2,4的右子树高为0。 两者高度差为2,此时这棵树不是平衡二叉树,那么就需要将其转换成平衡二叉树(先按照这个例子来进行,下面会说明其他情况):具体操作如下:
先将必要类和方法写出:

class Node{int value;Node left;Node right;public Node(int value) {super();this.value = value;}//添加结点public void add(Node node) {if(node==null) {System.out.println("此结点为空,不可添加");	return;}if(this.value>node.value) {if(this.left==null) {this.left=node;}else {this.left.add(node);}}else {if(this.right==null) {this.right=node;}else {this.right.add(node);}}}@Overridepublic String toString() {return "Node [value=" + value + "]";}//中序遍历public void infixOrder() {if(this.left!=null) {this.left.infixOrder();}System.out.println(this);if(this.right!=null) {this.right.infixOrder();}}
}

同时:我们还要写计算左子树高和右子树高的方法!这个方法可以帮助我们判断当添加数据之后是否需要进行转化。

	//计算左子树的高度public int leftHeigh() {if(left==null) {return 0;}return left.height();}//计算右子树的高度public int rightHeigh() {if(right==null) {return 0;}return right.height();}//计算结点的树高度public int height() {return Math.max(left==null ? 0 : left.height(), right==null?0:right.height())+1;}

当有了这些方法之后就可以进行转换了:举韩老师在课堂上的例子4,3,6,5,7,8在这里插入图片描述
当我们添加完8后,发现不满足平衡二叉树的条件了,就需要对其进行操作使其转化成平衡二叉树,这里的操作叫做左旋(当然还有右旋,双旋,放到后面来讲那些例子)!
操作如下:将其分为两步,很简单就是赋值的两步操作;
第一步.创建新节点,
新结点的值=当前结点的值(也就是4);
新结点的左节点=当前节点的左节点(3)
新结点的右节点=当前结点的右结点的左节点(5)
第二步.修改当前节点
当前结点的值=当前节点的右节点
当前节点的右子树=当前节点的右子树的右子树
当前节点的左子树=新结点

这里第一步的操作实质上可以理解成,将上面三个点记录下来,作为第二步当前结点的右节点在这里插入图片描述
第二步的操作为:将当前节点的值修改成6,并将当前节点的左右结点修改,如图,到此,转化过程就到此结束了,(这里的白色6因为没有被任何的GC roots指向,将会被回收)
在这里插入图片描述左旋的代码

	public void leftRotate() {//创建新节点Node node=new Node(this.value);//对新结点进行操作node.left=this.left;node.right=this.right.left;//修改当前节点this.value=this.right.value;this.right=this.right.right;this.left=node;}

在add方法加上左旋转的代码

		if(this.rightHeigh()-this.leftHeigh()>1) {this.leftRotate();}

右旋

其实右旋和左旋的操作相似,举个例子10,12,8,9,7,6
在这里插入图片描述当添加6后,发现需要调整,调整的操作也为两步
第一步.创建新节点,
新结点的值=当前结点的值(也就是10);
新结点的右节点=当前节点的右节点(12)
新结点的左节点=当前结点的左结点的右节点(9)
第二步.修改当前节点
当前结点的值=当前节点的左节点的值(8)
当前节点的左子树=当前节点的左子树的左子树
当前节点的右子树=新结点
在这里插入图片描述
右旋方法

	//右旋转public void rightRotate() {//创建新节点Node node = new Node(this.value);//操作新节点node.left=this.left.right;node.right=this.right;//修改当前节点this.value=this.right.value;this.left=this.left.left;this.right=node;}

在add方法添上如下代码

		if(this.leftHeigh()-this.rightHeigh()>1) {this.rightRotate();}

双旋

但是当我们遇到这样的情况该怎么办呢?
如:左子树高>右子树---->采用右旋(但是当前节点的左子树的左子树高>它的左子树的右子树)
举例:10,7,11,6,8,9
7的左子树高(1)<右子树高(2)
在这里插入图片描述
我们发现直接右旋无法将其转化成平衡二叉树!
解决办法:
当我们发现:7的左子树高(1)<右子树高(2),先对7进行左旋,将其转化成左子树高>右子树高的形式,操作步骤如下图,
在这里插入图片描述先将左子树(7)进行左旋之后,我们就可以直接将整棵树进行右旋了!
小结一下:当发现整个树需要右旋的时候,我们要先判断对于它的左子树,是否存在 它的左子树的左子树高<它的左子树的右子树高的情况,若存在,则需要先对左子树进行左旋!再对其进行右旋!

对于整棵树要先左旋的情况,我们要先判断对于它的右子树,是否存在 它的左=右子树的左子树高>它的左=右子树的右子树高的情况,若存在,则需要先对左子树进行右旋!再对整棵树进行左旋!
对add进行调整修改

		//左子树高>右子树高===>右旋转if(this.leftHeigh()-this.rightHeigh()>1) {if(this.left!=null&&this.left.leftHeigh()<this.left.rightHeigh()) {this.left.leftRotate();}this.rightRotate();}//右子树高》左子树高---》左旋转if(this.rightHeigh()-this.leftHeigh()>1) {if(this.right!=null&&this.right.leftHeigh()>this.right.rightHeigh()) {this.right.rightRotate();}this.leftRotate();}

至此,对于左旋,右旋,双旋的情况进行了详细的分析!建议大家在纸上画一下左旋右旋的示意图,希望对大家有帮助!
韩顺平老师数据结构与算法连接:
https://www.bilibili.com/video/BV1E4411H73v?p=135


http://chatgpt.dhexx.cn/article/YMsOtMOT.shtml

相关文章

图示讲解AVL平衡二叉树的左旋和右旋

AVLTree 高度平衡的搜索二叉树 一棵平衡树&#xff0c;或是空树&#xff0c;或是具有以下性质的二叉搜索树&#xff1a;左子树和右子树都是AVL树&#xff0c;且左右子树的高度之差的绝对值不超过1。 该二叉树&#xff0c;根结点的右子树高度为3&#xff0c;左子树高度为2。…

左右旋对比

目录 前言 一&#xff0c;逆置法 1.1逆置思路 1.2逆置实现 二&#xff0c;左旋和右旋对比 右旋代码分析 特点对比 前言 之前在up主的博客里面已经有过了对于左旋的三种实现方法。当然&#xff0c;如果我们考虑到时间复杂度的问题&#xff0c;那么我们只要一种方法&#xf…

平衡二叉树的左旋右旋详解 看不懂你打我

平衡二叉树的左旋右旋 看不懂你打我 左旋右旋的操作为什么要左旋右旋左旋右旋能保持排序二叉排序树的性质吗下次写平衡二叉树的LL、RR、LR、RL。 左旋右旋的操作 1.左旋&#xff1a;对X节点左旋&#xff0c;即以X的右孩子Y为轴&#xff0c;将X节点转下来&#xff0c;变为Y的左…

二叉树的旋转,左旋和右旋

在AVLTree中经常会有以某个节点为点对子树进行旋转的操作&#xff0c;今天就和大家分享一下什么是二叉树的旋转。 这是一棵二叉树&#xff0c;上图称为图一。 将图一中的树以1为旋转点进行左旋后得到图二&#xff1a; 将图一中的树以1为旋转点进行右旋旋后得到图三&#xff1…

day062:平衡二叉树——左旋、右旋

二叉树、平衡二叉树的介绍&#xff1a;day061&#xff1a;二叉树、二叉查找树、平衡二叉树_ZQyyds&#xff1a;&#xff09;的博客-CSDN博客 目录 一、平衡二叉树的左旋 1.为什么要左旋、右旋&#xff1f; 2.什么是左旋&#xff1f; 3.图解 二、平衡二叉树的右旋 1.什么是…

大型json文件格式化【超简单】

问题 遇到了一个很大的JSON文件&#xff08;约4M&#xff09;&#xff0c;想格式化查看&#xff0c;在线json工具会直接崩溃&#xff0c;网上其他同学说的python方法之类的我也都实验失败&#xff0c;但是发现了vs code中一个超强的代码格式化 解决1&#xff08;2019.2.10更…

Unity存档系统——Json格式的文件

实例场景 点击Save按钮后&#xff0c;查看保存的文件 点击Load按钮后加载文档数据 Json介绍https://www.json.org/json-zh.htmlUnity中自带的JsonUtility可以将可序列化对象与Json格式相互转换。 将对象转为可序列化对象需要添加[SerializeField]&#xff0c;且为public&#…

将json文件格式转化成Excel表格形式

在程序员的工作中&#xff0c;经常有产品或者运营部门的小姐姐需要数据&#xff0c;由于不懂技术&#xff0c;就需要我们将Json格式的数据转换成Excel文档提供给她们进行数据分析。 本文就介绍一个非常简单方便的方法 1.运用的是Excel表格自带的功能 首先打开Excel文件 点击插…

js导出JSON格式文件

在src目录下新建tools文件价&#xff0c;在tools文件中新建index.js(文件内名字随意) 在index.js文件中 const Tools {// 导出文件exportJson(name, data) {let blob new Blob([data]); // 创建 blob 对象let link document.createElement("a");link.href URL.…

json文件

认识一下 json文件 直接使用记事本打开&#xff1a;例如猫狗二分类 一般都使用类似字典的方式存储&#xff0c;但和字典不同&#xff0c;无论是键还是值&#xff0c;都要加上双引号。 json文件的读取与写入 import jsondata {"a":"1","b":&q…

JSON格式校验工具

经常用ApiPost 和 Postman 测试自己写的接口的话&#xff0c;有时会不小心写错传进去的json对象&#xff0c;我们可以用json格式检验工具去检查一下自己json格式。 在线工具&#xff1a;在线 JSON 工具&#xff0c;JSON 校验/格式化/压缩/工具 - 在线工具-wetools.com微工具

python文件处理——JSON格式文件

python文件处理——JSON格式文件 hello&#xff01;我是wakeyo_J&#xff0c;每天一个konwledge point&#xff0c;一起学python&#xff0c;让技术无限发散。 JSON格式文件 python文件处理——JSON格式文件1. JSON格式1.1 JSON常用的两种结构数据类型1.2 JSON数据与python数据…

json文件格式详解

json文件格式详解 JSON(JavaScript Object Notation) 是一种轻量级的数据交换格式。 易于人阅读和编写。同时也易于机器解析和生成。 它基于JavaScript Programming Language, Standard ECMA-262 3rd Edition - December 1999的一个子集。 JSON采用完全独立于语言的文本格式&a…

json文件格式转换为png文件格式

话不多少&#xff0c;直接上代码&#xff0c;更换源目录和目标目录即可 1、导入库 import cv2 import numpy as np import os import shutil import matplotlib.pyplot as plt 2、设置源目录/输出目录 json_dir G:/json_filedir/ #json文件所在文件夹(注&#xff1a;文…

Notepad++工具 格式化Json文件格式

简介&#xff1a; Notepad是常用的文件查看工具&#xff0c;在查看json的文件时&#xff0c;如果json文件的格式不符合正常的可视格式&#xff0c;那就需要格式化json文件&#xff0c;使之符合我们的可视化需求。 流程&#xff1a; 首先打开Notepad 打开Plugins 在搜索框中填入…

JSON 文件存储

&#x1f4cb; 个人简介 &#x1f496; 作者简介&#xff1a;大家好&#xff0c;我是W_chuanqi&#xff0c;一个编程爱好者 &#x1f4d9; 个人主页&#xff1a;W_chaunqi &#x1f600; 支持我&#xff1a;点赞&#x1f44d;收藏⭐️留言&#x1f4dd; &#x1f4ac; 愿你我共…

JSON 文件格式

最近的开发中用到了JSON文件&#xff0c;JSON是网络中比较常用的数据交换格式&#xff0c;Google chrome 浏览器的书签文件就采用了JSON格式。 以下是官方网站对JSON的介绍&#xff0c;URL&#xff1a;http://json.org//json-zh.html JSON(JavaScript Object Notation) 是一种…

json文件格式标准

JSON(JavaScript Object Notation) 是一种轻量级的数据交换格式。 易于人阅读和编写。同时也易于机器解析和生成。 它基于JavaScript Programming Language, Standard ECMA-262 3rd Edition – December 1999的一个子集。 JSON采用完全独立于语言的文本格式&#xff0c;但是也使…

Json文件格式化方法

1. JSON 是一种存储和交换数据的语法 当数据在浏览器与服务器之间进行交换时&#xff0c;这些数据只能是文本。 JSON 属于文本&#xff0c;并且我们能够把任何 JavaScript 对象转换为 JSON&#xff0c;然后将 JSON 发送到服务器。 我们也能把从服务器接收到的任何 JSON 转换…