平衡二叉树的定义

平衡二叉树(balanced binary tree),又称AVL树(Adelson-Velskii and Landis)。 一棵平衡二叉树或者是空树或者是具有下列性质的二叉排序树

① 左子树与右子树的高度之差的绝对值小于等于1

② 左子树和右子树也是平衡二叉排序树。 为了方便起见,给每个结点附加一个数字,给出该结点左子树与右子树的高度差。这个数字称为结点的平衡因子(BF)。

平衡因子 = 结点左子树的高度 - 结点右子树的高度

根据平衡二叉树的定义,平衡二叉树上所有结点的平衡因子只能是-1、0,或1

我们分析一下这个二叉树

对于40,左子树高度是2(看左子树有几层),右子树高度是3,2-3=-1,所以40的平衡因子是-1,平衡

对于24,左子树高度是0,对右子树高度为1,0-1=-1,24的平衡因子是-1,以此类推

我们直接分析一下53,53的左子树高度是0,右子树高度是2,所以0-2=-2,失衡

如果在一棵 AVL 树中插入一个新结点后造成失衡,则必须重新调整树的结构,使之恢复平衡

平衡调整的四种类型:

C表示的是插入的结点,怎么插入的分了上边四种类型

调整原则:1)降低高度 2)保持二叉排序树性质

对于LL型的,对根节点进行顺时针旋转,RR型是根节点A逆时针旋转

我们也可以通过平衡后要满足二叉排序树的性质,比如对上图的LL型,C<B<A,所以调整的时候,根据左子树小于根小于右子树的性质,B作为根,C作为左子树,A作为右子树

对上图的LR型,B<C<A,则C作为根节点,B作为左子树,A作为右子树

插入2,2比5小,在左子树,2比4小,是4的左子树,插入顺序是LL型,发现失衡了,于是将根节点5顺时针旋转下来即可

插入9,发现插入的是RR型,失衡了以后,将根节点4逆时针旋转,即6作为根节点,4作为6的左子树,而6的左子树作为4的右子树,也就是下图:

我们发现插入的类型是LR型,那么将叶子节点7升上去,作为根节点,然后3和16比较大小,小的3放入7的左子树,大的16放入7的右子树

我们插入8,发现是RL型,将RL型的叶子节点9升上去,7作为9的左子树,11作为9的右子树,9原本的左子树作为7的右子树

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如若转载,请注明出处:http://www.pswp.cn/diannao/95974.shtml
繁体地址,请注明出处:http://hk.pswp.cn/diannao/95974.shtml
英文地址,请注明出处:http://en.pswp.cn/diannao/95974.shtml

如若内容造成侵权/违法违规/事实不符,请联系英文站点网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

深入解析:如何设计灵活且可维护的自定义消息机制

深入解析&#xff1a;如何设计灵活且可维护的自定义消息机制 引言 在现代软件开发中&#xff0c;组件间的通信机制至关重要。无论是前端框架中的组件交互&#xff0c;还是后端服务间的消息传递&#xff0c;一个良好的消息机制能显著提升代码的可维护性和扩展性。本文将深入探讨…

PostgreSQL——用户管理

PostgreSQL用户管理一、组角色管理1.1、创建组角色1.2、查看和修改组角色1.3、删除组角色二、角色的各种权限2.1、LOGIN&#xff08;登录&#xff09;2.2、SUPERUSER&#xff08;超级用户&#xff09;3.3、CREATEDB&#xff08;创建数据库&#xff09;3.4、CREATEROLE&#xff…

东软8位MCU使用问题总结

简介用的单片机为ES7P7021&#xff0c;采用8位RISC内核&#xff0c;2KB的FLASH&#xff0c;128bit的RAM。编译器使用东软提供的iDesigner&#xff0c;开发过程中编译器和单片机有一些地方使用时需要注意下。1.RAMclear()函数注意问题/****************************************…

深度学习在订单簿分析与短期价格预测中的应用探索

一、订单簿数据特性及预处理 1.1 订单簿数据结构解析 在金融交易领域&#xff0c;订单簿是市场微观结构的集中体现&#xff0c;它记录了不同价格水平的买卖订单信息。一个典型的订单簿由多个层级组成&#xff0c;每个层级包含特定价格上的买单和卖单数量。例如&#xff0c;在某…

Hashmap源码

目录 HashMap底层原理 JDK1.8及以后底层结构为&#xff1a;数组链表红黑树 默认参数 扩容机制 数组 链表 红黑树 HashMap为什么用红黑树不用B树 HashMap什么时候扩容 HashMap的长度为什么是 2的 N 次方 HashMap底层原理 JDK1.8及以后底层结构为&#xff1a;数组链表红…

【JAVA 字符串常量池、new String的存储机制、==与equals的区别,以及字符串重新赋值时的指向变化】

系列文章目录 提示&#xff1a;这里可以添加系列文章的所有文章的目录&#xff0c;目录需要自己手动添加 提示&#xff1a;写完文章后&#xff0c;目录可以自动生成&#xff0c;如何生成可参考右边的帮助文档 文章目录系列文章目录代码原理解错误逻辑理解理解与修正&#xff1a…

博客项目 Spring + Redis + Mysql

基础模块1. 邮箱发送功能最初设计的接口 &#xff08;雏形&#xff09;public interface EmailService {/*** 发送验证码邮件** param email 目标邮箱* return 发送的code* throws RuntimeException 如果发送邮件失败&#xff0c;将抛出异常*/String sendVerificationCode(Stri…

前端处理导出PDF。Vue导出pdf

前言&#xff1a;该篇主要是解决一些简单的页面内容导出为PDF1.安装依赖使用到两个依赖&#xff0c;项目目录下运行这两个//页面转换成图片 npm install --save html2canvas //图片转换成pdf npm install jspdf --save 2.创建通用工具类exportPdf.js文件可以保存在工具类目录下…

【GM3568JHF】FPGA+ARM异构开发板烧录指南

1. Windows烧录说明 SDK 提供 Windows 烧写工具(工具版本需要 V3.31或以上)&#xff0c;工具位于工程根目录&#xff1a; tools/ ├── windows/RKDevTool 如下图&#xff0c;编译生成相应的固件后&#xff0c;设备烧写需要进入 MASKROM 或 LOADER 烧写模式&#xff0c;准备…

C++ 多进程编程深度解析【C++进阶每日一学】

文章目录一、引言二、核心概念&#xff1a;进程 (Process)功能与作用三、C 多进程的实现方式四、核心函数详解1. fork() - 创建子进程函数原型功能说明返回值完整使用格式2. wait() 和 waitpid() - 等待子进程结束函数原型参数与返回值详解3. exec 系列函数 - 执行新程序函数族…

一周学会Matplotlib3 Python 数据可视化-绘制面积图(Area)

锋哥原创的Matplotlib3 Python数据可视化视频教程&#xff1a; 2026版 Matplotlib3 Python 数据可视化 视频教程(无废话版) 玩命更新中~_哔哩哔哩_bilibili 课程介绍 本课程讲解利用python进行数据可视化 科研绘图-Matplotlib&#xff0c;学习Matplotlib图形参数基本设置&…

北京JAVA基础面试30天打卡11

1.索引创建注意事项 适合的场景 1.频繁使用where语句查询的字段 2.关联字段需要建立索 3.如果不创建索引&#xff0c;那么在连接的过程中&#xff0c;每个值都会进行一次全表扫描 4.分组和排序字段可以建立索引因为索引天生就是有序的&#xff0c;在分组和排序时优势不言而喻 5…

vscode无法检测到typescript环境解决办法

有一个vitereacttypescript项目&#xff0c;在工作电脑上一切正常。但是&#xff0c;在我家里的电脑运行&#xff0c;始终无法检测到typescript环境。即使出现错误的ts语法&#xff0c;也不会有报错提示&#xff0c;效果如下&#xff1a;我故意将一个string类型&#xff0c;传入…

【MCP开发】Nodejs+Typescript+pnpm+Studio搭建Mcp服务

MCP服务支持两种协议&#xff0c;Studio和SSE/HTTP&#xff0c;目前官方提供的SDK有各种语言。 开发方式有以下几种&#xff1a; 编程语言MCP命令协议发布方式PythonuvxSTUDIOpypiPython远程调用SSE服务器部署NodejspnpmSTUDIOpnpmNodejs远程调用SSE服务器部署… 一、初始化项…

vscode使用keil5出现变量跳转不了和搜索全局不了

vscode使用keil5出现变量跳转不了&#xff0c;或者未包含文件&#xff0c;或者未全局检索&#xff1b; 参考如下文章后还会出现&#xff1b; 为什么vscode搜索栏只搜索已经打开的文件_vscode全局搜索只能搜当前文件-CSDN博客 在机缘巧合之下发现如下解决方式&#xff1a; 下载…

命名空间——网络(net)

命名空间——网络&#xff08;net&#xff09; 一、网络命名空间&#xff1a;每个都是独立的“网络房间” 想象你的电脑是一栋大楼&#xff0c;每个网络命名空间就是大楼里的一个“独立房间”&#xff1a; 每个房间里有自己的“网线接口”&#xff08;网卡&#xff09;、“门牌…

一文读懂16英寸笔记本的实际尺寸与最佳应用场景

当您搜索"16寸笔记本电脑长宽"时&#xff0c;内心真正在问的是什么&#xff1f;是背包能否容纳&#xff1f;桌面空间是否足够&#xff1f;还是期待屏幕尺寸与便携性的完美平衡&#xff1f;这个看似简单的尺寸数字背后&#xff0c;凝结着计算机制造商对用户体验的深刻…

Android Studio中创建Git分支

做一些Android项目时&#xff0c;有时候想要做一些实验性的修改&#xff0c;这个实验可能需要很多步骤&#xff0c;所以不是一时半会能完成的&#xff0c;这就需要在实验的过程中不断修改代码&#xff0c;且要提交代码&#xff0c;方便回滚或比较差异&#xff0c;但是既然是实验…

内存可见性和伪共享问题

文章目录什么是内存可见性问题为什么会出现可见性问题解决可见性问题的方法1. 使用volatile关键字2. 使用synchronized3. 使用java.util.concurrent包下的原子类什么是伪共享问题CPU缓存行伪共享的危害解决伪共享的方法1. 缓存行填充2. 使用Contended注解&#xff08;JDK 8&…

Spring MVC 九大组件源码深度剖析(三):ThemeResolver - 动态换肤的奥秘

文章目录一、主题机制的核心价值二、核心接口设计三、四大实现类源码解析1. FixedThemeResolver&#xff08;固定主题策略&#xff09;2. CookieThemeResolver&#xff08;Cookie存储策略&#xff09;3. SessionThemeResolver&#xff08;Session存储策略&#xff09;4. Abstra…