使用C++编写一个AVL的增删改查代码并附上代码解释
//qq460219753提供其他代码帮助
#include <iostream>
using namespace std;struct Node
{int data;Node *left;Node *right;int height;
};// 获取结点高度
int height(Node *node)
{if (node == nullptr){return 0;}return node->height;
}// 获取两个数中较大的一个
int max(int a, int b)
{return (a > b) ? a : b;
}// 创建新结点
Node *newNode(int data)
{Node *node = new Node();node->data = data;node->left = nullptr;node->right = nullptr;node->height = 1;return node;
}// 右旋操作
Node *rightRotate(Node *y)
{Node *x = y->left;Node *T2 = x->right;// 进行旋转x->right = y;y->left = T2;// 更新高度y->height = max(height(y->left), height(y->right)) + 1;x->height = max(height(x->left), height(x->right)) + 1;// 返回新的根结点return x;
}// 左旋操作
Node *leftRotate(Node *x)
{Node *y = x->right;Node *T2 = y->left;// 进行旋转y->left = x;x->right = T2;// 更新高度x->height = max(height(x->left), height(x->right)) + 1;y->height = max(height(y->left), height(y->right)) + 1;// 返回新的根结点return y;
}// 获取平衡因子
int getBalanceFactor(Node *node)
{if (node == nullptr){return 0;}return height(node->left) - height(node->right);
}// 插入结点
Node *insert(Node *node, int data)
{if (node == nullptr){return newNode(data);}if (data < node->data){node->left = insert(node->left, data);}else if (data > node->data){node->right = insert(node->right, data);}else{return node;}// 更新高度node->height = 1 + max(height(node->left), height(node->right));// 获取平衡因子int balanceFactor = getBalanceFactor(node);// 左旋操作if (balanceFactor > 1 && data < node->left->data){return rightRotate(node);}// 右旋操作if (balanceFactor < -1 && data > node->right->data){return leftRotate(node);}// 左右旋操作if (balanceFactor > 1 && data > node->left->data){node->left = leftRotate(node->left);return rightRotate(node);}// 右左旋操作if (balanceFactor < -1 && data < node->right->data){node->right = rightRotate(node->right);return leftRotate(node);}// 返回不需要平衡的结点return node;
}
// 获取最小值结点
Node *minValueNode(Node *node)
{Node *current = node;// 找到最左侧结点while (current->left != nullptr){current = current->left;}return current;
}
// 删除结点
Node *deleteNode(Node *root, int data)
{if (root == nullptr){return root;}// 寻找要删除的结点if (data < root->data){root->left = deleteNode(root->left, data);}else if (data > root->data){root->right = deleteNode(root->right, data);}else{// 结点只有一个孩子结点或没有孩子结点if ((root->left == nullptr) || (root->right == nullptr)){Node *temp = root->left ? root->left : root->right;// 没有孩子结点的情况if (temp == nullptr){temp = root;root = nullptr;}else{*root = *temp;}delete temp;}else{// 结点有两个孩子结点Node *temp = minValueNode(root->right);root->data = temp->data;root->right = deleteNode(root->right, temp->data);}}// 如果树中只有一个结点,则返回if (root == nullptr){return root;}// 更新高度root->height = 1 + max(height(root->left), height(root->right));// 获取平衡因子int balanceFactor = getBalanceFactor(root);// 左旋操作if (balanceFactor > 1 && getBalanceFactor(root->left) >= 0){return rightRotate(root);}// 右旋操作if (balanceFactor < -1 && getBalanceFactor(root->right) <= 0){return leftRotate(root);}// 左右旋操作if (balanceFactor > 1 && getBalanceFactor(root->left) < 0){root->left = leftRotate(root->left);return rightRotate(root);}// 右左旋操作if (balanceFactor < -1 && getBalanceFactor(root->right) > 0){root->right = rightRotate(root->right);return leftRotate(root);}// 返回不需要平衡的结点return root;
}// 查找结点
Node *search(Node *node, int data)
{if (node == nullptr || node->data == data){return node;}if (node->data < data){return search(node->right, data);}return search(node->left, data);
}// 中序遍历
void inorder(Node *root)
{if (root != nullptr){inorder(root->left);cout << root->data << " ";inorder(root->right);}
}int main()
{Node *root = nullptr;// 插入结点root = insert(root, 10);root = insert(root, 20);root = insert(root, 30);root = insert(root, 40);root = insert(root, 50);root = insert(root, 25);// 中序遍历树cout << "Inorder traversal of the AVL tree is: " << endl;inorder(root);cout << endl;// 删除结点root = deleteNode(root, 25);// 中序遍历树cout << "Inorder traversal of the AVL tree after deleting 25 is: " << endl;inorder(root);cout << endl;return 0;
}
运行结果如下
代码解释:
Node 结构体定义:定义了 AVL 树结点的数据结构。
height 函数:用于获取结点的高度,如果结点为空则返回 -1。
getBalanceFactor 函数:用于获取结点的平衡因子,平衡因子为左子树的高度减去右子树的高度。
leftRotate 函数:用于左旋操作。
rightRotate 函数:用于右旋操作。
insert 函数:用于插入结点。首先进行普通的二叉搜索树插入操作,然后对树进行平衡操作。
minValueNode 函数:用于获取 AVL 树中最小的结点。
deleteNode 函数:用于删除结点。首先进行普通的二叉搜索树删除操作,然后对树进行平衡操作。
search 函数:用于查找结点。
inorder 函数:用于中序遍历 AVL 树。
main 函数:创建 AVL 树,插入结点,进行中序遍历,删除结点,再次进行中序遍历。
相关文章:
![](https://img-blog.csdnimg.cn/a1c560979c734ecf93214f44bed9090e.png)
使用C++编写一个AVL的增删改查代码并附上代码解释
//qq460219753提供其他代码帮助 #include <iostream> using namespace std;struct Node {int data;Node *left;Node *right;int height; };// 获取结点高度 int height(Node *node) {if (node nullptr){return 0;}return node->height; }// 获取两个数中较大的一个 i…...
![](https://www.ngui.cc/images/no-images.jpg)
React/ReactNative 状态管理: redux-toolkit 如何使用
有同学反馈开发 ReactNative 应用时状态管理不是很明白,接下来几篇文章我们来对比下 React 及 ReactNative 状态管理常用的几种框架的使用和优缺点。 上一篇文章介绍了 redux 的使用,这篇文章我们来看下 redux 的升级版:redux-toolkit。 下…...
![](https://img-blog.csdnimg.cn/e85741140a59462fbe016e6188e462e6.png)
14基于双层优化的电动汽车优化调度研究
说明书 MATLAB代码:基于双层优化的电动汽车优化调度研究 关键词:双层优化 选址定容 输配协同 时空优化 参考文档:《考虑大规模电动汽车接入电网的双层优化调度策略_胡文平》中文版 《A bi-layer optimization based temporal and sp…...
![](https://www.ngui.cc/images/no-images.jpg)
古茗科技面试:为什么 ElasticSearch 更适合复杂条件搜索?
文章目录 ElasticSearch 简介倒排索引联合索引查询跳表合并策略Bitset 合并策略MySQL 最多使用一个条件涉及的索引来过滤,然后剩余的条件只能在遍历行过程中进行内存过滤。 上述这种处理复杂条件查询的方式因为只能通过一个索引进行过滤,所以需要进行大量的 I/O 操作来读取行…...
![](https://img-blog.csdnimg.cn/c3eb759563fe4e9e9eb550ea8f5bf1ec.png)
【数据结构】哈希表
目录 1、哈希表 1.1 哈希表的简介 1.2 降低哈希冲突率 1.3 解决哈希冲突 1.3.1 闭散列 1.3.2 开散列(哈希桶) 1、哈希表 1.1 哈希表的简介 假设我们目前有一组数据,我们要从这组数据中找到指定的 key 值,那么咱们目…...
![](https://www.ngui.cc/images/no-images.jpg)
物联网常用协议MQTT协议相关介绍
概述 MQTT(Message Queuing Telemetry Transport)是一种轻量级的消息传输协议,旨在在网络带宽有限的情况下,为物联网设备之间的通信提供可靠的、低延迟的消息传递服务。MQTT协议具有订阅/发布模式,支持多种传输协议&a…...
![](https://img-blog.csdnimg.cn/35ecf198531945f286ea4ff5bf7d61a6.jpeg#pic_center)
【C语言进阶】13. 假期测评②
day10 1. int类型字节数 求函数返回值,传入 -1 ,则在64位机器上函数返回( ) int count 0; int x -1; while (x) {count;x x >> 1; } printf("%d", count);A: 1 B: 2 C: 32 D: 死循环,没结果 【答案解析】C xx&(x-1)这…...
![](https://img-blog.csdnimg.cn/img_convert/7c87ac603060844c7ce3b75de2b96b6b.png)
【国产FPGA】国产FPGA搭建图像处理平台
最近收到了高云寄过来的FPGA板卡,下图:来源:https://wiki.sipeed.com/hardware/zh/tang/tang-primer-20k/primer-20k.htmlFPGA主要参数:FPGA型号参数GW2A-LV18PG256C8/I7逻辑单元(LUT4) 20736寄存器(FF) 15552分布式静态随机存储器S-SRAM(bit…...
![](https://img-blog.csdnimg.cn/0f0c332b2cd74f26951c81d61c1b4178.png)
你的应用太慢了,给我司带来了巨额损失,该怎么办
记得很久之前看过谷歌官方有这么样的声明:如果一个页面的加载时间从 1 秒增加到3 秒,那么用户跳出的概率将增加 32%。 但是早在 2012 年,亚马逊就计算出了,页面加载速度一旦下降一秒钟,每年就会损失 16 亿美元的销售额…...
![](https://img-blog.csdnimg.cn/38c4f0da6fb24917b3ddf471f737b6fe.png)
第十四届蓝桥杯三月真题刷题训练——第 22 天
目录 第 1 题:受伤的皇后_dfs 题目描述 输入描述 输出描述 输入输出样例 运行限制 代码: 思路: 第 2 题:完全平方数 问题描述 输入格式 输出格式 样例输入 1 样例输出 1 样例输入 2 样例输出 2 评测用例规模与约…...
![](https://img-blog.csdnimg.cn/61687de608d14c6a86ceb44f9d4a5267.png)
机器学习:朴素贝叶斯模型算法原理(含实战案例)
机器学习:朴素贝叶斯模型算法原理 作者:i阿极 作者简介:Python领域新星作者、多项比赛获奖者:博主个人首页 😊😊😊如果觉得文章不错或能帮助到你学习,可以点赞👍收藏&…...
![](https://img-blog.csdnimg.cn/2308796d12a443db92648b553295f9ee.jpeg#pic_center)
Linux 多线程:理解线程
目录一、理解线程的思想二、Linux中的线程与进程1.Linux中的进程2.Linux中的线程三、线程的工作方式四、线程的独有数据与共享数据1.独有数据2.共享数据一、理解线程的思想 线程就是把一个进程分成多个执行部分,一个部分就是一个线程,比如可以让一个线程…...
![](https://img-blog.csdnimg.cn/7bac8ab8cbdf45aa8abd100b0c4f1109.png)
Web前端学习:章四 -- JavaScript初级(四)-- BOM
138:Object数据格式简介 1、object对象 JS中独有 的一种数据格式 名字可以随便取,值一般就那几种数据格式 139:BOM - JS跳转页面 BOM Browser Object Model:浏览器对象模型 使用JavaScript控制浏览器交互 控制浏览器里面的内…...
![](https://img-blog.csdnimg.cn/5c716e0eefac420cbe6cd59c5fd4bebd.png)
Lesson9.网络基础1
网络协议初识 所谓的协议就是人们为了通信的一种约定 操作系统要进行协议管理,必然会先描述,再组织协议本质就是软件,软件是可以"分层"协议在设计的时候,就是被层状的划分的, 为什么要划分成为层状结构 场景复杂功能解耦(便于人们进行各种维护)OSI七层模型 局域网中…...
![](https://img-blog.csdnimg.cn/img_convert/4f756c61770e11cf1f68e2df1c66c07c.png)
这几个SQL语法的坑,你踩过吗
本文已经收录到Github仓库,该仓库包含计算机基础、Java基础、多线程、JVM、数据库、Redis、Spring、Mybatis、SpringMVC、SpringBoot、分布式、微服务、设计模式、架构、校招社招分享等核心知识点,欢迎star~ Github地址:https://github.com/…...
![](https://img-blog.csdnimg.cn/793b977f158f4247b66b06fc4ca78c78.png)
算法基础——复杂度
前言 算法是解决问题的一系列操作的集合。著名的计算机科学家Niklaus Wirth曾提出:算法数据结构程序,由此可见算法在编程中的重要地位。本篇主要讨论算法性能好坏的标准之一——复杂度。 1 复杂度概述 1.1 什么是复杂度 本文所讨论的复杂度是指通过事先…...
![](https://img-blog.csdnimg.cn/cba59e324f264c95be49b790b85ca4d7.jpeg)
基类与派生类对象的关系 派生类的构造函数
🐶博主主页:ᰔᩚ. 一怀明月ꦿ ❤️🔥专栏系列:线性代数,C初学者入门训练,题解C,C的使用文章,「初学」C 🔥座右铭:“不要等到什么都没有了,才下…...
![](https://img-blog.csdnimg.cn/a9118c6035a3446cae62fd6e54bd51bb.png)
【算法】生成分布式 ID 的雪花算法
ID 是数据的唯一、不变且不重复的标识,在查询数据库的数据时必须通过 ID 查询,在分布式环境下生成全局唯一的 ID 是一个重要问题。 雪花算法(snowflake)是一种生成分布式环境下全局唯一 ID 的算法,该算法由 Twitter 发…...
![](https://img-blog.csdnimg.cn/a6fce92223d74f9ba34e4ddb10797179.png)
Linux系统编程 - 基础IO(IO操作)
目录 预备知识 复习C文件IO相关操作 printf相关函数 fprintf snprintf 读取文件 系统文件IO操作 open函数 umask()函数 open函数返回值 预备知识 1.你真的理解文件原理和操作了吗?不是语言问题,是系统问题2.是不是只有C/C有文件操作呢&#x…...
![](https://www.ngui.cc/images/no-images.jpg)
基于 Avue 的 CRUD 表格组件封装
在 components 文件夹中,创建一个新的 .vue 文件,例如:AvueCrudTable.vue。 透传父组件传递的属性和事件 : 1、利用v-bind=“ a t t r s " 支持所有 a v u e 的使用方法并在其基础上进行封装 2 、使用 v − o n = " attrs"支持所有 avue 的使用方法并在其基…...
![](https://www.ngui.cc/images/no-images.jpg)
树莓派学习笔记(十三)基于框架编写驱动代码
文章目录一、代码分析:二、源码一、代码分析: 在内核中由于代码文件多,避免函数名重复,使用static将函数的作用域限制在该文件内 内核的打印函数printk和printf类似 file_operations结构体使用符号“ . ”指定参数,省…...
![](https://img-blog.csdnimg.cn/4bd9154e7d8c448680dd959fc1e79571.png)
vue事件修饰符之.prevent
.prevent 事件修饰符只是阻止默认事件,不会自动触发任何事件处理函数。因此,在使用 .prevent 事件修饰符时,需要自己编写相应的事件处理函数来处理事件。 例如,在上面的例子中,我们通过在表单上绑定 submit.prevent&q…...
![](https://img-blog.csdnimg.cn/c63ba5597c8d42faa4a0af1e3a88739c.png)
【SpringCloud AlibabaSentinel实现熔断与限流】
本笔记内容为尚硅谷SpringCloud AlibabaSentinel部分 目录 一、Sentinel 1、官网 2、Sentinel是什么 3、下载 4、特性 5、使用 二、安装Sentinel控制台 1、sentinel组件由2部分构成 2、安装步骤 1.下载 2.运行命令 3.访问sentinel管理界面 三、初始化演示工程 …...
![](https://img-blog.csdnimg.cn/img_convert/53b1b800084538ef3cc30d1040291475.png)
类与对象-封装
一、封装的意义封装是C面向对象三大特性之一语法: class name { 访问权限:属性行为 };注意:类中的属性和行为 统称为成员属性 又称 成员属性 / 成员变量行为 又称 成员函数 / 成员方法封装将属性和行为作为一个整体,表现生活中的事物例①&…...
![](https://img-blog.csdnimg.cn/e936faf2f1d149e9afe56aa1af71d3ba.png)
【回忆杀】2012年拥有第一台电脑【致逝去的青春】
高中说起 在2012年的时候吧,高考过后,那个时候一门心思的想当一名体育老师【现在居然还有这个想法,哈哈】,最后没有考上自己希望的大学我记得好像是2012年7月的时候就去重庆投靠朋友,他教我做模具,2012年做…...
![](https://img-blog.csdnimg.cn/511aae8d579240cd888d3287238baa16.png)
PointNeXt: Revisiting PointNet++ with Improved Training and Scaling Strategies
Abstract PointNet 是点云理解领域最有影响力的神经网络架构之一。虽然近期出现了 PointMLP 和 Point Transformer 等新型网络,它们的精度已经大大超过了 PointNet,但我们发现大部分性能提升是由于改进的训练策略,例如数据增强和优化技术以及…...
![](https://img-blog.csdnimg.cn/2901148a5531422d889fdca7f042d9f3.png)
打印九九乘法表-课后程序(JavaScript前端开发案例教程-黑马程序员编著-第2章-课后作业)
【案例2-9】打印九九乘法表 一、案例描述 考核知识点 for双重循环 练习目标 掌握for循环应用。实现九九乘法表。 需求分析 九九乘法表相信大家一点也不陌生,之前见到的乘法表是印刷在课程本之上的。而在本案例中我们将用JavaScript代码来实现九九乘法表。 案例分…...
![](https://img-blog.csdnimg.cn/60e3a6028436421990ad737ca37d4375.png#pic_center)
【Linux】基于阻塞队列的生产者消费者模型
🌠 作者:阿亮joy. 🎆专栏:《学会Linux》 🎇 座右铭:每个优秀的人都有一段沉默的时光,那段时光是付出了很多努力却得不到结果的日子,我们把它叫做扎根 目录👉为何要使用…...
![](https://www.ngui.cc/images/no-images.jpg)
【华为OD机试 2023最新 】 真正的密码(C++)
文章目录 题目描述输入描述输出描述用例题目解析C++题目描述 在一行中输入一个字符串数组,如果其中一个字符串的所有以索引0开头的子串在数组中都有,那么这个字符串就是潜在密码, 在所有潜在密码中最长的是真正的密码,如果有多个长度相同的真正的密码,那么取字典序最大的…...
![](https://www.ngui.cc/images/no-images.jpg)
差分算法(蓝桥杯复习+例题讲解+模板c++)
文章目录差分介绍差分应用区间加区间求和总结3729. 改变数组元素100. 增减序列文章首发于:My Blog 欢迎大佬们前来逛逛 差分介绍 差分是一种常见的算法,用于快速修改数组中某一段区间的值。 差分的思想就是预处理出数组的差分数组,然后修改…...
![](https://s1.51cto.com/images/blog/201908/09/0b5eb67ca4bca645573fd9afa00c0956.png?x-oss-process=image/watermark,size_16,text_QDUxQ1RP5Y2a5a6i,color_FFFFFF,t_100,g_se,x_10,y_10,shadow_90,type_ZmFuZ3poZW5naGVpdGk=)
上网建站推广/网上销售方法
数据库概念 关系型数据库 关系数据库提供了一个通用接口,使用户可以使用使用 编写的命令或查询从数据库读取和写入数据。关系数据库由一个或多个表格组成,表格由与电子表格相似的列和行组成。 以行列形式存储数据,行包含一个条目的所有信息&a…...
![](/images/no-images.jpg)
蛋糕店网站设计模板/东莞最新消息 今天
为 OEA 框架 做 WPF 树型表格控件时,浪费了许多时间在一些知识点上,所以写了这篇博客总结一下,和各位博友分享。 ICollectionView 接口的简易使用方法 它的 SortDescriptions、GroupDescription 等属性会影响视图的结构,一般情况下…...
![](/images/no-images.jpg)
网站建建设公司和网络自建/如何提升百度关键词排名
输液是很多人在治疗疾病的时候所使用的一种给药方式,但是部分患者在输液的过程中很有可能长期输入浓度过高的药液,或者是静脉内放置的刺激性导管的实际过长,亦或者是在输液的过程中所采用的无菌操作不过全面,从而导致静脉感染的情…...
![](https://img-blog.csdnimg.cn/img_convert/c698d8157f3cbe7ff8793a7a65583a05.png)
福州专业网站建设/天津百度网站排名优化
lambda表达式含义 函数式接口 1.什么是函数式接口 2.自定义函数 3.作为参数传递Lambda表达式 4.四大内置核心函数式接口 方法引用与构造器引用 方法引用 构造器引用(了解) 数组引用(了解) lambda表达式含义 lambda表达…...
![](/images/no-images.jpg)
凤台县美丽乡村建设网站/营销网点机构号
1.面向对象的思想主要包括什么?2.什么是ASP.net中的用户控件3.什么叫应用程序域?什么是受管制的代码?什么是强类型系统?什么是装箱和拆箱?什么是重载?CTS、CLS和CLR分别作何解释?4.列举一下你所…...
![](/images/no-images.jpg)
网站建设教程搭建汽岁湖南岚鸿专注/网络营销流程
类似问题答案兰州理工大学计算机与通信学院的学生都能考上哪些学校的研究生这个要看个人实力,毕竟适合自己的才是最好的。哪个学校都有牛人,但是牛人也只是牛人,与我们自己无关。我们自己所需要做的就是分析自己的长短处,然后选一…...