代码随想录算法训练营第二十三天|617.二叉搜索树的最小绝对差、501.二叉搜索树中的众数、236. 二叉树的最近公共祖先

news/2024/5/20 21:47:59

617.二叉搜索树的最小绝对差

文档讲解:代码随想录

题目链接:. - 力扣(LeetCode)

遇到二叉搜索树,就要知道这棵树在中序遍历的情况下是一个升序的遍历。

这道题目的难点就是如何使用双指针遍历二叉树,一个指向中序遍历的正在遍历的节点,一个指向中序遍历前一个结点

在中序遍历过程中,遍历到的节点是不断递增的,相当于有一个指针是不断移动的,我们只要让另一个指针指向现在指针指向的指针就可以

如何确定递归函数有无返回值:有返回值的情况:返回二叉树是否符合某一特性或者某一结点的数值,遍历某条特定的路径,或是找到某一结点,本题是需要遍历整个二叉树所以无返回值

class Solution:def __init__(self):self.result = float("inf")self.pre = Nonedef traversal(self,root):if not root:return self.traversal(root.left) #向左遍历#中if self.pre is not None: self.result = min(self.result,root.val - self.pre.val)self.pre = root#右self.traversal(root.right)def getMinimumDifference(self, root: Optional[TreeNode]) -> int:self.traversal(root)return self.result

501.二叉搜索树中的众数

文档讲解:代码随想录

题目链接:. - 力扣(LeetCode)

涉及到二叉搜索树,遍历顺序一定是中序遍历,中序遍历的才是一个升序数组。然后将处理逻辑放在中间,和上一个题的结构是一样的,在向左遍历和向右遍历中间写上处理代码。

难点:众数可能有多个

所以我们要对每个不一样的元素都初始化一个count,比较哪个count最大,并且如果有跟count一样大的其他元素对应的count,那么这两个元素都是众数

代码技巧①和上一题一样,也是使用双指针 ②定义两个频率变量,一个是当前遍历的元素的频率count,一个是所有的遍历过的元素的最高频率max_count  ③收获结果集:如果count和max_count 一样,就保存到结果集中 ④在遍历的过程中不断更新max_count,以及结果集

class Solution:def findMode(self, root: Optional[TreeNode]) -> List[int]:###定义全局变量pre = Nonecount = 0max_count = 0result = []def traversal(root):nonlocal pre, count, max_count, resultif not root:return traversal(root.left)#统计当前节点的频率if pre == None:count = 1else:if pre.val == root.val:count +=1else:count = 1#比较当前节点的频率和最大频率if count > max_count:max_count = countresult = [root.val] #重置###下面这个条件不可以写为if,这个条件和上面的是互斥的,如果写为if那么上面那个执行完之后,max_count = count了,下面的if条件还是会执行elif  count == max_count:result.append(root.val)##不要忘记更新pre的值pre = roottraversal(root.right)traversal(root)return result

236. 二叉树的最近公共祖先

文档链接:代码随想录

题目链接:. - 力扣(LeetCode)

审题:

  • 所有 Node.val 互不相同 。
  • p != q
  • p 和 q 均存在于给定的二叉树中。

如果找到一个节点,发现左子树出现结点p,右子树出现节点q,或者 左子树出现结点q,右子树出现节点p,那么该节点就是节点p和q的最近公共祖先。也就是我们要从下往上处理

 遍历是没有办法从下往上遍历的,但是处理顺序可以从下往上处理,后序遍历,左右中,便是从下往上处理。有递归就会有回溯,回溯的过程就会让我们从底往上去遍历

class Solution:def lowestCommonAncestor(self, root: 'TreeNode', p: 'TreeNode', q: 'TreeNode') -> 'TreeNode':if root == None or root.val == p.val or root.val == q.val: #如果一个节点是根节点,那么不论另一个节点在哪里,最近公共祖先都是该根节点return rootleft = self.lowestCommonAncestor(root.left,p,q)right = self.lowestCommonAncestor(root.right,p,q)if left and right:return rootif left and not right:return leftelif not left and right:return rightelse:return None


http://www.mrgr.cn/p/17621872

相关文章

SpringCloud微服务之Eureka、Ribbon、Nacos详解

SpringCloud微服务之Eureka、Ribbon、Nacos详解 1、认识微服务1.1、单体架构1.2、分布式架构1.3、微服务1.4、SpringCloud 2、服务拆分与远程调用2.1、服务拆分的原则2.2、服务拆分示例2.2、提供者与消费者 3、Eureka注册中心3.1、Eureka的结构和作用3.2、搭建eureka-server3.2…

Sealos急速部署生产用k8s集群

最近一段时间部署k8s全部使用sealos了,整体使用感觉良好,基本没有什么坑。推荐给大家。 使用 Sealos,可以安装一个不包含任何组件的裸 Kubernetes 集群。 最大的好处是提供 99 年证书,用到我跑路是足够了。不用像之前kubeadm安装…

小程序引入 Vant Weapp 极简教程

一切以 Vant Weapp 官方文档 为准 Vant Weapp 官方文档 - 快速入手 1. 安装nodejs 前往官网下载安装即可 nodejs官网 安装好后 在命令行(winr,输入cmd)输入 node -v若显示版本信息,即为安装成功 2. 在 小程序根目录 命令行/终端…

毕业设计:《基于 Prometheus 和 ELK 的基础平台监控系统设计与实现》

前言 《基于 Prometheus 和 ELK 的基础平台监控系统设计与实现》,这是我在本科阶段的毕业设计,通过引入 Prometheus 和 ELK 架构实现企业对指标与日志的全方位监控。并且基于云原生,使用容器化持续集成部署的开发方式,通过 Sprin…

95、动态规划-编辑距离

递归暴力解法 递归方法的基本思想是考虑最后一个字符的操作,然后根据这些操作递归处理子问题。 递归函数定义:定义一个递归函数 minDistance(i, j),表示将 word1 的前 i 个字符转换成 word2 的前 j 个字符所需的最小操作数。 递归终止条件…

day1_slidingWindow

一、滑动窗口模板 // 注意:java 代码由 chatGPT🤖 根据我的 cpp 代码翻译,旨在帮助不同背景的读者理解算法逻辑。 // 本代码不保证正确性,仅供参考。如有疑惑,可以参照我写的 cpp 代码对比查看。import java.util.Has…

C++ 引用

引用函数的形参还有引用传参这一形式 引用:是一个变量的别名,它是某个已经存在的变量的另一个名字。 引用创建后,不可更改 因不可更改,所以必须初始化 必须初始化,所以不可为空(不能被修改) 语法:引用传参语法:函数三种传参模式对比

.Net MAUI 搭建Android 开发环境

一、 安装最新版本 VS 2022 安装时候选择上 .Net MAUI 跨平台开发 二、安装成功后,创建 .Net MAUI 应用 三、使用 VS 自带的 Android SDK 下载 ,Android镜像、编译工具、加速工具 四、使用Vs 自带的 Android Avd 创建虚拟机 五、使用 Android 手机真机调试

基于springboot实现医院药品管理系统项目【项目源码+论文说明】

基于springboot实现医院药品管理系统演示 摘要 身处网络时代,随着网络系统体系发展的不断成熟和完善,人们的生活也随之发生了很大的变化,人们在追求较高物质生活的同时,也在想着如何使自身的精神内涵得到提升,而读书就…

AI 绘画神器 Fooocus 本地部署指南:简介、硬件要求、部署步骤、界面介绍

本文收录于《AI绘画从入门到精通》专栏,专栏总目录:点这里,订阅后可阅读专栏内所有文章。 大家好,我是水滴~~ 随着人工智能技术的飞速发展,AI 绘画逐渐成为创意领域的新宠。Fooocus 作为一款免费开源的 AI 绘画工具&am…

一文玩转Vue3参数传递——全栈开发之路--前端篇(8)

全栈开发一条龙——前端篇 第一篇:框架确定、ide设置与项目创建 第二篇:介绍项目文件意义、组件结构与导入以及setup的引入。 第三篇:setup语法,设置响应式数据。 第四篇:数据绑定、计算属性和watch监视 第五篇 : 组件…

测试项目实战——安享理财1(测试用例)

说明: 1.访问地址: 本项目实战使用的是传智播客的安享理财项目(找了半天这个项目能免费用且能够满足测试实战需求) 前台:http://121.43.169.97:8081/ 后台:http://121.43.169.97:8082/ (点赞收藏…

20240503解决Ubuntu20.04和WIN10双系统下WIN10的时间异常的问题

20240503解决Ubuntu20.04和WIN10双系统下WIN10的时间异常的问题 2024/5/3 9:33 缘起:因为工作需要,编译服务器上都会安装Ubuntu20.04。 但是因为WINDOWS强悍的生态系统,偶尔还是有必须要用WINDOWS的时候,于是也安装了WIN10。 双系…

什么是虚拟货币?

随着科技的进步,虚拟货币逐渐进入公众视野,其影响深远且复杂。本文将从专业角度分析虚拟货币的发展现状、未来趋势,以及面临的挑战,并尝试提出一些思考。 一、虚拟货币的定义与现状 虚拟货币是一种基于区块链技术的数字资产&…

欧洲杯/奥运会-云直播

欧洲杯/奥运会要来了,如何升级自己的网站让你的顾客都能观赏直播已提高用户量呢?! 【功能完善、平滑兼容】 云直播支持 RTMP 推流、 HLS 源站等多种直播源接入方式,提供直播 SDK,支持多终端适配,上行码率…

【C++】详解STL容器之一的deque和适配器stack,queue

目录 deque的概述 deque空间的结构 deque的迭代器 deque的数据设计 deque的优缺点 适配器的概念 ​编辑 stack的概述 stack的模拟实现 queue的概述 queue的模拟实现 deque的概述 deque的设计参考了另外两大容器vector和list。可参考下面两篇文章 详解vector&#x…

【LLM 论文】Least-to-Most Prompting 让 LLM 实现复杂推理

论文:Least-to-Most Prompting Enables Complex Reasoning in Large Language Models ⭐⭐⭐ Google Research, ICLR 2023 论文速读 Chain-of-Thought(CoT) prompting 的方法通过结合 few-show prompt 的思路,让 LLM 能够挑战更具…

漏洞管理是如何在攻击者之前识别漏洞从而帮助人们阻止攻击的

漏洞管理 是主动查找、评估和缓解组织 IT 环境中的安全漏洞、弱点、差距、错误配置和错误的过程。该过程通常扩展到整个 IT 环境,包括网络、应用程序、系统、基础设施、软件和第三方服务等。鉴于所涉及的高成本,组织根本无法承受网络攻击和数据泄露。如果…

【springboot基础】如何搭建一个web项目?

正在学习springboot,还是小白,今天分享一下如何搭建一个简单的springboot的web项目,只要写一个类就能实现最基础的前后端交互,实现web版helloworld ,哈哈,虽然十分简陋,但也希望对你理解web运作…