数据结构之二叉树的暴力删除

删除节点

删除某个节点,如果非叶子节点,则将其下对应的子树均删除,纯属暴力删除,代码如下:

java 复制代码
/**
     * 删除节点, 如果该节点有子树的话, 将子树一起删除
     */
    public void deleteById(Integer id) {
        if (Objects.isNull(id)) {
            System.out.println("id为空, 无需处理");
            return;
        }
        PersonNode left = this.getLeft();
        if (Objects.nonNull(left)) {
            if (id.equals(left.getData().getId())) {
                this.setLeft(null);
            } else {
                this.getLeft().deleteById(id);
            }
        }
        PersonNode right = this.getRight();
        if (Objects.nonNull(right)) {
            if (id.equals(right.getData().getId())) {
                this.setRight(null);
            } else {
                this.getRight().deleteById(id);
            }
        }
    }

源码与测试案例

gitee地址

相关推荐
勇敢滴勇1 小时前
【排序算法】插入排序_直接插入排序、希尔排序
c语言·数据结构·算法·排序算法
骑着居居追飞机3 小时前
Pandas数据结构
数据结构·pandas
gugugu.3 小时前
数据结构:二叉树OJ题(基础版)
数据结构
张三xy3 小时前
数据结构 第三章 栈和队列 练习题3.2.4 迷宫求解 C语言代码
c语言·数据结构·算法
misty youth3 小时前
有理数四则运算
c语言·数据结构·算法·c#
程序员波特3 小时前
基础数据结构之数组
java·数据结构·算法·leetcode
¥ 多多¥9 小时前
数据结构:内存的使用
linux·c语言·开发语言·数据结构
小灰灰爱代码9 小时前
C++——将数组a[5]={-1,2,9,-5,7}中小于0的元素置成0。并将其结果输出(要求:用数组名作为函数的参数来实现)
数据结构·c++·算法
liuyang-neu11 小时前
力扣中等 33.搜索旋转排序数组
java·数据结构·算法·leetcode