算法训练营day22

embedded/2024/9/24 8:27:59/
一、二叉搜索树的最近公共祖先
java">class Solution {public TreeNode lowestCommonAncestor(TreeNode root, TreeNode p, TreeNode q) {//得到p q的最大值,跟root比较//max < root 向左遍历 ,max > root 继续比较 min > root 向右遍历; min < root root就是最近公共节点if (root.val < p.val && root.val < q.val)return lowestCommonAncestor(root.right, p, q);if (root.val > p.val && root.val > q.val)return lowestCommonAncestor(root.left, p, q);return root;}
}
二、二叉搜索树的插入操作

参考链接701. 二叉搜索树中的插入操作 - 力扣(LeetCode)

大前提:该树节点值是不重复的

java">class Solution {public TreeNode insertIntoBST(TreeNode root, int val) {
//如果root为空,即当前节点为空,说明这个位置可以插入新节点,于是创建一个值为val的新节点并返回。 或者(在递归当中) 如果 root 是空,则新建树节点作为根节点返回即可if (root == null) {return new TreeNode(val);  //终止条件}
//递归调用
//如果root不为空,需要根据当前节点的值与val的大小关系来确定插入的位置。如果root的值小于val,说明val应该插入到右子树中。相反,如果root的值大于或等于val,说明val应该插入到左子树中。if (root.val < val) { root.right = insertIntoBST(root.right, val);} else {root.left = insertIntoBST(root.left, val);}//返回结果return root;}
}

二叉搜索树的平均深度是 log⁡n,最坏情况是由于有序插入数据导致二叉搜索树退化成一条链表,此时深度是 n。因此上述两种解法的平均时间复杂度是 O(log⁡n),最坏时间复杂度是 O(n)。迭代写法的空间复杂度是 O(1),递归写法由于递归调用时会使用方法栈,而方法栈的深度就是二叉搜索树的深度,所以最坏空间复杂度是 O(n)。

所以说,二叉搜索树的深度是非常影响查找/插入性能的,所以说并不常用,广泛使用的是平衡搜索树。常见的平衡搜索树有 红黑树,B- 树,B+ 树(还有 ACM/OI 大佬们爱的 treap,splay,SBT)等。比如 Java 里的 TreeMap,TreeSet 和 HashMap 中链表的树化都是用红黑树实现的,又比如 InnoDB 的索引存储就是 B+ 树实现的。感兴趣的同学可以去学习下~学成归来之时,可以问候别人——能不能心里有点 B 树~

三、删除二叉搜索树中的节点

重点:当删除当前节点时,使用哪个节点来替代被删除节点? 使用左子树的最大节点 或 右子树的最小节点 来替代保持 二叉搜索树的性质

java">class Solution {public TreeNode deleteNode(TreeNode root, int key) {if (root == null) return null;if (root.val == key) {
//找到相等的值时判断左右子树是否为空,左子树为空返回右子树,右子树为空返回左子树,也适用于都为空的情况(return root.right;)if (root.left == null) return root.right;if (root.right == null) return root.left;
//如果都不为空,则遍历到左子树的最右端(最大值)TreeNode t = root.left;while (t.right != null) t = t.right;t.right = root.right;return root.left;//如果key不等于当前节点值 key > 向右递归,< 向左递归} else if (root.val < key) root.right = deleteNode(root.right, key);else root.left = deleteNode(root.left, key);//返回值return root;}
}

http://www.ppmy.cn/embedded/14922.html

相关文章

Node.js -- fs模块

文章目录 1. 写入文件1.1 写入文件1.2 同步和异步1.3 文件追加写入1.4 流式写入1.5 文件写入的场景 2. 读取文件2.1 异步和同步读取2.2 读取文件应用场景2.3 流式读取2.4 fs 练习 -- 文件复制 3. 文件重命名和移动4. 文件删除5. 文件夹操作5.1 创建文件夹5.2 读取文件夹5.3 删除…

通过阿里云OOS实现定时备份redis实例转储到OSS

功能背景 随着企业业务数据的快速增长&#xff0c;Redis 作为高性能的内存数据存储方案&#xff0c;在多种应用场景下承担着重要的角色。为确保数据安全&#xff0c;定时备份成为了不可或缺的一环。Redis 实例定时备份是关键数据库管理任务的一个重要组成部分&#xff0c;它主…

Flask项目部署

1.debug模式 不用每次保存后重新运行&#xff08;热部署&#xff09; 看一下自己的ip ipconfig2.改host 可以让同一个局域网的人访问 3.修改port端口号 中间有空格

uniapp 小程序 多张图片生成海报以及下载海报

uniapp 小程序 多张图片生成海报以及下载海报 上代码 export default {data() {return {unit: 0,imgurl:"", // 海报图片shareimg:"https://eshopfile.zhiyousx.com/2022051811164947691.jpg", //背景图qrcode :"", // 二维码saveTop:80,}},on…

Linux编辑器-vim使用

&#x1f496;作者&#xff1a;对自己好点儿i ❤️‍&#x1fa79;作者宣言&#xff1a;认真写好每一篇博客 目录 前言 一、Linux编辑器-vim使用 命令模式 &#xff1a;set nu 显示行号 yy p 复制粘贴 np u&#xff1a;撤销 dd p 剪切 粘贴 ndd p shift 4 $:将…

Python 数据库基类封装

目录 1.BaseEntity 2.t_user 3.DAOBase 4.UserDAO 刚开始用Python做Api后端&#xff0c;记录下学习过程 从数据库操作开始&#xff0c;定义实体&#xff0c;定义DAO层基类&#xff0c;及DAO业务类的使用 写的不好&#xff0c;有好的设计建议欢迎大家提出&#xff0c;一起…

保护你的网站:了解5种常见网络攻击类型及其防御方法

随着互联网的迅猛发展&#xff0c;针对网站的各种类型的网络攻击随之增加&#xff0c;网络攻击事件层出不穷&#xff0c;由此&#xff0c;如何保护网站安全成为每个网站所有者的重要议题。在下面的内容中&#xff0c;我们将探讨5种常见网络攻击类型及其防御方法&#xff0c;以帮…

【Unity】苹果(IOS)开发证书保姆级申请教程

前言 我们在使用xcode出包的时候&#xff0c;需要用到iOS证书(.p12)和描述文件(.mobileprovision) 开发证书及对应的描述文件用于开发阶段使用&#xff0c;可以直接将 App 安装到手机上&#xff0c;一个描述文件最多绑定100台测试设备 1.证书管理 进入网站Apple Developer &…