day20 450. 删除二叉搜索树中的节点701. 二叉搜索树中的插入操作235. 二叉搜索树的最近公共祖先

news/2025/2/11 21:05:32/文章来源:https://www.cnblogs.com/lin0304/p/18710483
  1. 删除二叉搜索树中的节点
    核心思路:删除操作需要根据节点的不同情况分别处理。如果删除的是叶子节点,直接删除即可;如果删除的节点只有一个子树,用该子树替换被删除的节点;如果删除的节点有两个子树,则需要找到左子树的最大值或右子树的最小值来替代被删除的节点。
    代码逻辑:
    deleteNode 方法:首先判断根节点是否为目标节点,如果是则直接调用 deleteRoot 方法处理;否则通过 findParent 方法找到目标节点的父节点,再根据目标节点在父节点的左右位置,调用 deleteRoot 方法删除目标节点。
    deleteRoot 方法:处理删除根节点的逻辑。根据根节点的左右子树情况,分别返回相应的子树或调整子树结构。
    findMax 方法:用于找到左子树的最大值。
    findParent 方法:通过递归找到目标节点的父节点。
    //450. 删除二叉搜索树中的节点
    public TreeNode deleteNode(TreeNode root, int key) {
    if (root != null && root.val == key) {
    return deleteRoot(root);
    }
    TreeNode parent = findParent(root, key);
    if (parent != null && parent.val > key) {
    parent.left = deleteRoot(parent.left);
    } else if (parent != null && parent.val < key) {
    parent.right = deleteRoot(parent.right);
    }
    return root;
    }
private TreeNode deleteRoot(TreeNode root) {if (root == null) {return null; // 如果根节点为空,直接返回 null}// 如果根节点没有左子树,直接返回右子树if (root.left == null) {return root.right;}// 如果根节点没有右子树,直接返回左子树if (root.right == null) {return root.left;}int max = findMax(root.left);// 将左子树的最大值节点的值赋给根节点root.val = max;// 删除左子树中的最大值节点root.left = deleteNode(root.left, max);return root;
}private int findMax(TreeNode root) {if (root == null) return 0;while (root.right != null) {root = root.right;}return root.val;
}private TreeNode findParent(TreeNode root, int key) {if (root == null) return null;if (root.left == null && root.right == null) return null;if ((root.left != null && root.left.val == key) || (root.right != null && root.right.val == key)) return root;if (root.val > key && root.left != null) {return findParent(root.left, key);} else if (root.val < key && root.right != null) {return findParent(root.right, key);}return null;
}
  1. 二叉搜索树中的插入操作
    核心思路:根据二叉搜索树的性质,新插入的节点总是插入到某个叶子节点的位置。
    代码逻辑:
    insertIntoBST 方法:如果根节点为空,则直接创建一个新节点作为根节点;否则调用 insert 方法进行插入操作。
    insert 方法:通过递归找到合适的插入位置,然后创建新节点并插入。
    //701. 二叉搜索树中的插入操作
    public TreeNode insertIntoBST(TreeNode root, int val) {
    if (root == null) {
    return new TreeNode(val);
    }
    insert(root, val);
    return root;
    }
private void insert(TreeNode root, int val) {if (root.val == val) {return;} else if (root.val > val) {if (root.left == null) {root.left = new TreeNode(val);} else {insert(root.left, val);}} else {if (root.right == null) {root.right = new TreeNode(val);} else {insert(root.right, val);}}
}
  1. 二叉搜索树的最近公共祖先
    核心思路:利用二叉搜索树的性质,通过比较节点值的大小来确定最近公共祖先的位置。
    代码逻辑:
    lowestCommonAncestor1 方法:递归判断当前节点与目标节点的大小关系。如果当前节点的值在两个目标节点值之间,则当前节点就是最近公共祖先;如果两个目标节点的值都大于当前节点,则递归到右子树;反之则递归到左子树。
    //235. 二叉搜索树的最近公共祖先
    public TreeNode lowestCommonAncestor1(TreeNode root, TreeNode p, TreeNode q) {
    if (root == null) return null;
    if (root.val == p.val || root.val == q.val) {
    return root;
    }
    if ((root.val > p.val && root.val < q.val) || (root.val < p.val && root.val > q.val)) {
    return root;
    } else if ((root.val < p.val)) {
    return lowestCommonAncestor1(root.right, p, q);
    } else {
    return lowestCommonAncestor1(root.left, p, q);
    }
    }

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

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

相关文章

P1083 [NOIP 2012 提高组] 借教室(差分)

说实话竟然没想到还能这样差分,这道题我们需要二分查找m个订单,对于每次二分用一次差分,然后看如果只考虑1到mid个订单是否会出现教室不够用的情况,如果够用说明导致教室不够用的订单在后面,应该让begin=mid+1;反之让end-1;其实这道题就是让我们找第一个出现教室不够用的…

来吃糖

先放犯错后 be like:1 return // 倍增求 lca int bfs(int x) {queue<int> q;q.push(x);dep[x] = 1;while (q.size()) {x = q.front(), q.pop();for (auto it : G[x]) {int y = it.first, z = it.second;if (dep[y]) continue;dep[y] = dep[x] + 1;d[0][y] = z;f[0][y] =…

P9330 [JOISC 2023] JOI 国的节日 2 题解

Description 对于以下问题:给定长度为 \(n\) 的序列 \(a\)、\(b\),满足以下条件:在序列 \(a\) 与序列 \(b\) 中,\(1\) 到 \(2n\) 的整数各出现恰好一次; 对于 \(1\leq i\leq n\),\(a_i<b_i\); 对于 \(1\leq i<n\),\(a_i<a_{i+1}\)。求:最多能在 \([a_i,b_i]\…

一站式合同自动化:飞书审批与腾讯电子签的完美融合

Z国际教育中心专注于将全球顶尖教育资源引入中国,通过本地化整合与优化,将这些优质资源转化为中国青年触手可及的学习机会。我们的使命是帮助学生培养深厚的家国情怀与开阔的国际视野,助力他们成长为未来社会的栋梁之才。 遇到的问题 1. 业务种类多,合同审批繁琐 通过飞书平…

Linux下Docker及Nvidia Container ToolKit安装教程

作者:SkyXZ CSDN:SkyXZ~-CSDN博客 博客园:SkyXZ - 博客园 我们接下来在Ubuntu中安装Docker(安装详见:Get Docker | Docker Docs)及NVIDIA Container Toolkit(安装详见:Installing the NVIDIA Container Toolkit — NVIDIA Container Toolkit 1.17.3 documentat…

在用 uni-app 开发钉钉小程序的时候遇到一个奇怪的问题,发送请求拿不到返回的数据

今天我一位同事说用 uni-app 新开发的钉钉小程序里发送请求拿不到返回的数据,看了下发现调试工具的“Network”栏里显示请求是发送成功的,也有返回数据,但是没触发请求的回调函数。 原本用的是 luch-request 这个库发送的请求,后来试了下 uni-app 内置的 uni.request 以及钉…

15. 进程处理

一、什么是进程进程(Process)是正在运行的程序,是操作系统进行资源分配的基本单位。程序是存储在硬盘或内存的一段二进制序列,是静态的,而进程是动态的。每个进程都由自己的地址空间、代码段、数据段以及分配给它的其它系统资源(如文件描述符、网络连接等)。 二、创建子…

我把deepseek等大模型接入了微信公众号,打造个人AI助手

我把deepseek等大模型接入了微信公众号,打造个人AI助手前言 最近deepseek大模型可是火出了圈,给国产大模型公司点赞。于是乎去deepseek试了一下效果,奈何太多人使用了,问两句来一句 “服务器繁忙,请稍后再试”,体验感实在太差了。 作为程序员,怎么能忍受?于是乎去寻找d…

(未解决)word中插入pdf图片(高清、矢量图)

(未解决)word中插入pdf图片(高清、矢量图) 1.个人诉求: pdf高清矢量格式的图片,插入至word中 2.尝试的解决方法: https://blog.csdn.net/weixin_45399376/article/details/115281547?spm=1001.2014.3001.5502。 3.具体操作步骤: 1)word——插入——对象——文件中的文…

一语总结

一语总结 真心建议把找到的一些性质和做法以文字形式写下来,当掉不过样例的时候一个一个检查其正确性。”P9169 [省选联考 2023] 过河卒“用DFS将环当作平局是错误的因为这可能只是一个不优的必胜/必败局面,正确的做法是老实建图按拓扑序跑BFS。就这个结论的错误害我虚空调题…

软考高级《系统架构设计师》知识点(二)

操作系统知识 操作系统概述操作系统定义:能有效地组织和管理系统中的各种软/硬件资源,合理地组织计算机系统工作流程,控制程序的执行,并且向用户提供一个良好的工作环境和友好的接口。 操作系统有三个重要的作用:管理计算机中运行的程序和分配各种软硬件资源; 为用户提供…