当前位置: 首页 > news >正文

有序二叉树的删除

  有序二叉树的删除需要考虑多种情况,其核心在于在删除节点之后,依然保持有序二叉树的性质,即左子树所有节点值 < 当前节点值 < 右子树所有节点值。

  下面,我们用如下这棵树作为例子,分析关于有序二叉树所要删除的目标节点的几种可能情况。

  我们大致可以将其分类为以下三种情况:

  • 目标节点为叶子节点(黄色节点)
  • 目标节点只有一颗子树(粉色节点)
  • 目标节点有两棵子树(绿色节点)

  当目标节点分别是这三种情况时,有序二叉树的删除该如何实现?

一、删除叶子结点

(一)逻辑方法

1、找到要删除的目标节点target;

2、判断目标节点是否有父节点parent;

3、如果没有父节点,即整棵树就只有一个节点,则root=null;

4、如果有父节点,判断父节点和目标节点的关系

  (1)目标节点是父节点的左孩子,则parent.left=null

  (2)目标节点是父节点的右孩子,则parent.right=null

(二)示例

(三)关键部分的代码实现

//如果没有父节点
if(parent==null) {root=null;return;
}
//如果有父节点
//判断目标节点是父节点的左孩子还是右孩子
if(parent.left!=null&&parent.left.value==num) {//目标节点是父节点的左孩子parent.left = null;
}else {//目标节点是父节点的右孩子parent.right=null;
}

二、删除只有一颗子树的节点

(一)逻辑方法

1、找到目标节点target;

2、判断目标节点是否有父节点parent;

3、如果没有父节点,即目标节点是根节点,且只有一颗子树

  (1)目标节点只有一颗左子树,则root=target.left;

  (2)目标节点只有一颗右子树,则root=target.right;

4、如果目标节点有父节点,判断目标节点和父节点的关系

  (1)目标节点是父节点的左孩子,且目标节点有一颗左子树,则parent.left=target.left;

  (2)目标节点是父节点的左孩子,且目标节点有一颗右子树,则parent.left=target.right;

  (3)目标节点是父节点的右孩子,且目标节点有一颗左子树,则parent.right=target.left;

  (4)目标节点是父节点的右孩子,且目标节点有一颗右子树,则parent.right=target.right;

(二)示例

(三)关键部分的代码实现

//目标节点右子树的最小值
Node index = target.right;
while (index.left!=null) {index=index.left;
}
//最小值
int min = index.value;//先删除
delete(min);
//替换
target.value = min;

三、删除两颗子树的节点

(一)逻辑方法

1、找到目标节点target;

2、找到目标节点左子树的最大值或右子树的最小值,替换目标节点的值;

3、删除目标节点左子树的最大值或右子树的最小值;

(二)示例

(三)关键部分的代码实现

//没有父节点
if(parent==null) {//判断目标节点有左子树还是右子树if(target.left!=null) {//目标节点有左子树root =  target.left;}else {//目标节点有右子树root =  target.right;}return;
}
//有父节点  判断目标节点和父节点的关系
//判断目标节点是父节点的左孩子还是右孩子
if(parent.left!=null&&parent.left.value==num) {//目标节点是父节点的左孩子//判断目标节点有左子树还是右子树if(target.left!=null) {//目标节点有左子树parent.left = target.left;}else {//目标节点有右子树parent.left = target.right;}
}else {//目标节点是父节点的右孩子//判断目标节点有左子树还是右子树if(target.left!=null) {//目标节点有左子树parent.right = target.left;}else {//目标节点有右子树parent.right = target.left;}
}

http://www.dtcms.com/a/341584.html

相关文章:

  • leetcode 3 无重复字符的最长子串
  • 个人使用AI开发的《PlSqlRewrite4GaussDB(PLSQL自动转换工具)1.0.1 BETA》发布
  • 【OneAI】使用Rust构建的轻量AI网关
  • linux环境问题
  • HyperMesh许可证分配优化策略
  • 【Ansible】变量、机密、事实
  • 福昕PDF编辑软件高级版下载与详细图文安装教程!!
  • Pub/Sub是什么意思
  • LWIP的Socket API 与实现关系
  • c#入门笔记(3)
  • 图像数据增强的高效执行
  • Linux下运行Jmeter压测
  • Kafka如何保证「消息不丢失」,「顺序传输」,「不重复消费」,以及为什么会发生重平衡(reblanace)
  • 攻克PostgreSQL专家认证
  • Git Commit 提交信息标准格式
  • Python打卡Day47 注意力热图可视化
  • 字符设备驱动、块设备驱动和网络设备驱动
  • Gitee仓库 日常操作详细步骤
  • Linux服务器性能优化总结
  • 【数据结构】快速排序算法精髓解析
  • shell脚本——搜索某个目录下带指定前缀的文件
  • 50.Seata-AT模式
  • Cyberduck (FTP和SFTP工具) v9.2.3.43590
  • 189.轮转数组
  • 设计模式的一些笔记
  • list集合可以一边遍历一遍修改元素吗?
  • Rust 入门 包 (二十一)
  • 计算机网络基础复习
  • 【数据分享】295个地级市互联网用户、邮电业务数据(2001-2022)
  • win10安装最新docker 4.44.2版图文教程(2025版)