二叉树 | Java | LeetCode 235 701 450 做题总结,BST特性、 调整二叉树结构(增+删)

news2024/11/16 15:35:29

235. 二叉搜索树的最近公共祖先

思路:要利用二叉搜索数的性质。当前遍历节点 cur 的数值大于p q时,说明 p q 的父节点在 cur 的左子树。当前遍历节点 cur 的数值小于p q时,说明 p q 的父节点在 cur 的右子树。当前遍历节点 cur 的数值在 p q 之间时,说明 cur 是 p q 的父节点。
cur是公共祖先,他一定是最近的公共祖先吗?是的,一定是。
根本不需要遍历到pq因为二叉搜索树有特性。

  • 出错
错误
Line 23: error: missing return statement
    }
    ^

在这里插入图片描述
这两种写法都是不对的,因为出了if else没有返回值

  • 正确写法
class Solution {
    public TreeNode lowestCommonAncestor(TreeNode root, TreeNode p, TreeNode q) {  
        if(p.val<root.val && q.val<root.val) {
            return lowestCommonAncestor(root.left, p,q);
        }    
        else if(p.val>root.val && q.val>root.val) {
            return lowestCommonAncestor(root.right, p,q);
        }
         return root;
    }
}

701.二叉搜索树中的插入操作

  • 写错了
class Solution {
    public TreeNode insertIntoBST(TreeNode root, int val) {
        if(root == null) {
            TreeNode tmp = new TreeNode(); // TreeNode<Integer>tmp = new TreeNode<>();这里不能这么写
            tmp.val = val;
            root = tmp;
            return root;
        }
        if(val > root.val){
            return insertIntoBST(root.right, val);
        }
        if(val < root.val){
            return insertIntoBST(root.left, val);
        }
    }
}

思路:插入一个节点,一定能放在叶子节点上

class Solution {
    public TreeNode insertIntoBST(TreeNode root, int val) {
        if(root == null) {
            TreeNode tmp = new TreeNode(); // TreeNode<Integer>tmp = new TreeNode<>();这里不能这么写
            tmp.val = val;
            return tmp;
        }
        if(val > root.val){
            //插入到他的右节点
            root.right =  insertIntoBST(root.right, val);
        }
        if(val < root.val){
            root.left =  insertIntoBST(root.left, val);
        }
        return root;
    }
}

450.删除二叉搜索树中的节点

1没找到删除的节点
2找到了待删除的节点cur
①cur是叶子节点,直接删除
②cur左子树不为空,右子树为空 => cur 父节点直接指向 cur的 左孩子节点
③cur左空右不空 => cur 父节点直接指向 cur的 右孩子节点
④cur左右都不空,选right右孩子继位(左也行),那么他的左子树放在哪里?放在right左子树最下面的一个
在这里插入图片描述

错误示范

一个函数找目标节点,另一个函数删除可行吗?不可行,因为要返回处理后的树给父节点,要用到递归。

class Solution {
    TreeNode target;
    public TreeNode deleteNode(TreeNode root, int key) {
        //找目标删除节点
        findNode(root, key);
        if(target == null) return null;

        deleteDetail(target);
    }
    public void findNode(TreeNode root, int key) {
        if(key > root.val) {
            findNode(root.right);
        }
        if(key < root.val) {
            findNode(root.left);
        }
        if(key == root.val) {
            target = root;
        }
    }
    public void deleteDetail(TreeNode cur) {
        //叶子节点
        
    }
}

正确答案

class Solution {
    public TreeNode deleteNode(TreeNode root, int key) {
      return deleteDetail(root,key);
    }

    //怎么表示找不到值为key的节点?
    //这个问题纯纯是题目没看明白,如果二叉树不为空,但找不到为KEY的节点,返回原二叉树
    public TreeNode deleteDetail(TreeNode cur,int key) {
        if(cur == null) {
            return null;
        }

        if(key > cur.val) {
            cur.right = deleteDetail(cur.right, key); //在cur的右子树处理完,返回给右节点
        }
        else if(key < cur.val) {
            cur.left = deleteDetail(cur.left, key);
        }
        if(key == cur.val) {
            //叶子节点
            if(cur.left == null && cur.right == null) {
                return null;
            }
            //只有左子树
            else if(cur.right == null) {
                return cur.left;
            }
            //只有右子树
            else if(cur.left == null) {
                return cur.right;
            }
            //左右孩子都有
            else {
                TreeNode node = cur.right;
                while(node.left!=null) node=node.left;
                node.left = cur.left;
                return cur.right;
            }
        }
        return cur;
    }
}

优化

优化:这种方法会让树的高度变很大,可以找右数最小去替代待删除的节点,只用交换右数最小和删除结点的值,然后就变成了删除右树最小的节点,这个节点一定是个叶子节点,树的结构变化小。

上面说法是B站代码随想录弹幕说的,但经我实践是错误的,因为右树(cur=root.right)最小的节点不一定是个叶子节点,可能没有左子树,那么根节点 cur 就是最小的。交换不了

这个应该可以,但好麻烦啊。
在这里插入图片描述

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

替代TPS7H1101A-SP抗辐射7V/3A大电流低压差稳压器|具有可并联使用达6A电流

1. 产品特性 ➢ 超低电压输入&#xff1a; 1.5V~7V ➢ 最大输出电流&#xff1a; 3A ➢ 电压精度&#xff1a; 1.25% ➢ 超低压降&#xff1a; 62mV1A&#xff08;Vout1.8V&#xff0c; 25℃&#xff09; ➢ 超低噪声&#xff1a; 20.33μVRMS&#xff08;BW10Hz-100kHz&a…

【Python机器学习】聚类算法的对比与评估——在没有真实值的情况下评估聚类

在实践中&#xff0c;使用诸如ARI之类的指标有一个很大的问题。在应用聚类算法时&#xff0c;通常没有真实值来比较结果。如果我们知道了数据的正确聚类&#xff0c;那么可以使用这一信息构建一个监督模型&#xff08;比如分类器&#xff09;。因此&#xff0c;使用类似ARI和NM…

springboot微信点餐小程序-计算机毕业设计源码82910

目 录 摘要 1 绪论 1.1 项目开发背景 1.2目的和意义 1.3springboot框架介绍 2 微信点餐小程序系统分析 2.1 可行性分析 2.2 系统流程分析 2.2.1 数据流程 3.3.2 业务流程 2.3 系统功能分析 2.3.1 功能性分析 2.3.2 非功能性分析 2.4 系统用例分析 2.5本章小结 …

AIGC->基于扩散模型的图像生成算法 (课程大纲)

https://edu.csdn.net/course/detail/39618?spm=1001.2014.3001.5507https://edu.csdn.net/course/detail/39618?spm=1001.2014.3001.5507 课程特色是围绕着工作中AIGC文生图的具体用途来对文生图领域进行一个高屋建瓴式的分析,结合具体的应用,尤其是产业界的具体实用场景,…

django图书推荐系统-计算机毕业设计源码89399

摘 要 随着时代的不断更新&#xff0c;社会的不断变换&#xff0c;信息技术的飞速发展&#xff0c;计算机科技技术也逐步走向成熟。图书推荐系统对于当今社会来说是必不可少的一个信息组成部分&#xff0c;它可以管理大量图书、大量读者、让读者有条不紊的进行评分图书&#xf…

ruoyi-vue-plus中使用minio

minio windwos中安装使用&#xff1a; 1、安装 minio下载页面 2、启动&#xff1a;ruoyi-vue-plus&#xff1a; 配置管理&#xff1a;

哈啰集团全面接入通义灵码,AI 生成代码占比 20%,研发提效 12%

6 月 21 日&#xff0c;在阿里云 AI 智领者峰会上海站&#xff0c;哈啰集团算法总监贾立宣布&#xff0c; 哈啰集团已全面接入阿里云通义灵码专属版&#xff0c; 不仅提升了内部研发效率&#xff0c;实现 AI 代码采用率超过 20%&#xff0c;还将灵码接入了哈啰自研 Copilot “海…

JSAPI微信支付提示缺少total_fee

微信小程序云开发中使用微信支付。莫名其妙的报错&#xff1a; 这个报错严重图文不符&#xff0c;驴唇不对马嘴&#xff0c;难排查&#xff0c;很恶心。 原因可能是&#xff1a; 1、在微信支付中关联appid&#xff1b; 2、在小程序云开发控制台中授权&#xff1a;

SecureCRT使用方法(非常简单)!!!

一、简单了解 SecureCRT是一款功能强大的终端仿真软件&#xff0c;广泛用于远程访问和管理服务器。它提供了丰富的功能和安全性&#xff0c;使得远程连接更加简单、高效和可靠。 SecureFX 可以提供安全文件传输。主要用于Linux操作系统客户端文件传输程序&#xff0c;该客户端…

刷题记录6.24

438. 找到字符串中所有字母异位词https://leetcode.cn/problems/find-all-anagrams-in-a-string/ 这道题乍一看感觉很复杂。因为 异位词指由相同字母重排列形成的字符串&#xff0c;包括相同的字符串&#xff0c;那么就会有很多种组成&#xff0c;增加题目的复杂性。 对于这个…

微信小程序修改应用名称

1、修改名称&#xff08;10分钟即可生效&#xff09; 账号管理员 2、修改icon&#xff08;如果logo带有名称则需要修改&#xff09;

【单片机毕业设计选题24025】-基于ESP32的车联网控制器设计

系统功能: 这个设计采用ESP32芯片作为核心控制器,搭配其它传感器,电源模块以及通信模块,用于实现车联网中的MQTT数据收发控制. ESP32芯片负责接收电路模块和相关传感器的数据,包括模拟信号,按键触发信号等, 随后ESP32进行数据处理并通过MQTT协议与通信模块协同工作将数据上传至…

短剧小程序源码:打造个性化的娱乐体验

在数字化媒体时代&#xff0c;短剧作为一种新兴的娱乐形式&#xff0c;正迅速受到全球用户的喜爱。短剧小程序源码作为这一趋势下的产物&#xff0c;为短剧的创作、分享和观看提供了一个全新的平台。本文将深入探讨短剧小程序源码的关键特性及其在全球化娱乐市场中的潜力。 一…

同城代驾小程序代驾平台APP代驾软件开发代驾JAVA系统源码

市场分析 随着现代社会的快速发展&#xff0c;人们的生活节奏日益加快&#xff0c;出行需求也愈发多样化。在繁忙的都市生活中&#xff0c;代驾服务以其便捷、安全的特点受到了广大用户的青睐。为了满足这一市场需求&#xff0c;代驾系统基础功能软件应运而生&#xff0c;通过…

Windows重新安装安全中心解决白屏问题

重新安装Windows安全中心&#xff08;Windows Security Center&#xff09;涉及多个步骤&#xff0c;包括重置Windows安全功能和重新安装Windows安全应用。以下是详细的步骤&#xff1a; 1. 通过PowerShell重置Windows安全中心 打开PowerShell: 在开始菜单中搜索“PowerShell”…

AIGC遇上ChatGPT,互联网公司的创意设计师,还能做什么?

随着科技的日新月异&#xff0c;AIGC&#xff08;人工智能生成内容&#xff09;和ChatGPT等AI技术的涌现&#xff0c;为互联网公司的创意设计师们描绘了一幅充满挑战与机遇的新图景。在这个数字化、智能化的新时代&#xff0c;创意设计师们不仅要保持敏锐的审美眼光和源源不断的…

精细化视频剪辑解决方案,数字人接入定制开发

为满足企业对于高质量、高效率视频制作的需求&#xff0c;美摄科技推出了全新的精细化视频剪辑解决方案。凭借多端专业的视频编辑工具、模板设计工具以及数字人接入定制开发服务&#xff0c;美摄科技为企业提供了一站式的视频剪辑体验&#xff0c;助力企业轻松打造专业级视频内…

社交风潮塑造者:探索用户在Facebook的影响力

在当今数字化社会中&#xff0c;Facebook不仅是人们社交互动的主要平台&#xff0c;更是塑造社交风潮和文化趋势的重要力量。本文将从另一个角度深入探讨用户在Facebook上的影响力&#xff0c;探索其如何通过个人行为和互动&#xff0c;影响和改变社会的各个方面。 个人表达和内…

【大数据技术原理与应用(概念、存储、处理、分析与应用)】第1章-大数据概述习题与知识点回顾

文章目录 单选题多选题知识点回顾几次信息化浪潮主要解决什么问题&#xff1f;信息科技为大数据时代提供哪些技术支撑&#xff1f;数据产生方式有哪些变革&#xff1f;大数据的发展历程大数据的四个特点&#xff08;4V&#xff09;大数据对思维方式的影响大数据有哪些关键技术&…

C++调试技巧总结

1.调试准备 常用调试 Crash调试 调试信息&#xff1a; Windows系统&#xff1a;符号单独PDB文件/链接时生成&#xff0c;从外部的符号服务器下载。&#xff08;微软&#xff09; LInux&#xff1a; 调试符号与目标模块在一个文件内&#xff0c;编译时产生调试信息。模块发布时…