代码随想录-Day21

2024-05-28 04:12
文章标签 随想录 代码 day21

本文主要是介绍代码随想录-Day21,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

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

给你一个二叉搜索树的根节点 root ,返回 树中任意两不同节点值之间的最小差值 。

差值是一个正数,其数值等于两值之差的绝对值。

class Solution {int pre;int ans;public int getMinimumDifference(TreeNode root) {ans = Integer.MAX_VALUE;pre = -1;dfs(root);return ans;}public void dfs(TreeNode root) {if (root == null) {return;}dfs(root.left);if (pre == -1) {pre = root.val;} else {ans = Math.min(ans, root.val - pre);pre = root.val;}dfs(root.right);}
}

这段代码定义了一个名为 Solution 的类,其中包含两个成员变量 preans 以及两个方法:getMinimumDifferencedfs。该类主要用于解决一个问题:在一棵给定的二叉搜索树(BST)中找到两个节点之间的最小差值(相邻节点间差值的最小值)。具体分析如下:

  1. 成员变量:

    • pre 初始化为 -1,用于存储中序遍历过程中前一个访问到的节点的值。
    • ans 初始化为 Integer.MAX_VALUE,用于记录遍历过程中找到的最小差值。
  2. 方法 getMinimumDifference(TreeNode root):

    • 这是主要的接口函数,接收BST的根节点 root 作为输入参数,返回找到的最小差值。
    • 首先,它初始化 ansInteger.MAX_VALUEpre-1(虽然 pre 已经在类级别初始化,这里可视为一种明确的逻辑起点标志)。
    • 然后调用深度优先搜索(DFS)方法 dfs,从根节点开始遍历整个BST。
    • 最后,返回找到的最小差值 ans
  3. 方法 dfs(TreeNode root):

    • 这是一个递归方法,用于实现深度优先搜索遍历BST。
    • 基本情况:如果当前节点 root 为空,则直接返回,结束当前递归路径。
    • 递归遍历左子树,确保按照BST的中序遍历顺序(左根右)访问节点。
    • 在访问当前节点 root 之前,先判断 pre 是否已经被初始化(即首次访问或之前已访问过节点)。如果是第一次访问(pre == -1),则将 pre 更新为当前节点值;否则,计算当前节点值与 pre 的差值,并更新全局最小差值 ans
    • 更新 pre 为当前节点值,准备与下一个节点比较。
    • 递归遍历右子树,继续按照中序遍历顺序访问节点。

通过这样的中序遍历策略,由于BST的中序遍历会得到一个升序序列,遍历过程中相邻节点值的差值自然就是我们需要找的最小差值。这种方法巧妙地利用了BST的性质,实现了对最小差值的有效查找。

501. 二叉搜索树中的众数

class Solution {List<Integer> answer = new ArrayList<Integer>();int base, count, maxCount;public int[] findMode(TreeNode root) {dfs(root);int[] mode = new int[answer.size()];for (int i = 0; i < answer.size(); ++i) {mode[i] = answer.get(i);}return mode;}public void dfs(TreeNode o) {if (o == null) {return;}dfs(o.left);update(o.val);dfs(o.right);}public void update(int x) {if (x == base) {++count;} else {count = 1;base = x;}if (count == maxCount) {answer.add(base);}if (count > maxCount) {maxCount = count;answer.clear();answer.add(base);}}
}

这段代码定义了一个名为 Solution 的类,用于解决一个与二叉树相关的算法问题:找到给定二叉树中出现次数最多的元素(即众数),并返回这些众数的数组。代码主要包含类的成员变量定义、一个主方法 findMode 以及两个辅助方法 dfsupdate

类成员变量

  • List<Integer> answer:用于存储众数。
  • int base:记录当前处理的元素值。
  • int count:记录当前元素值连续出现的次数。
  • int maxCount:记录目前遇到的最大连续出现次数。

方法 findMode

  • 功能:入口方法,用于启动查找众数的过程,接收二叉树的根节点 root 作为参数。
  • 过程:首先调用深度优先搜索(DFS)方法遍历整个二叉树,然后将找到的所有众数存储在 answer 列表中。最后,将 answer 列表的内容转换为整型数组并返回。

方法 dfs

  • 功能:递归方法,按照中序遍历(左根右)的顺序遍历二叉树。
  • 参数:当前访问的节点 o
  • 过程:递归遍历左子树,然后处理当前节点(调用 update 方法),最后递归遍历右子树。

方法 update

  • 功能:更新当前元素的计数,并根据计数更新众数信息。
  • 参数:当前遍历到的元素值 x
  • 过程:如果当前元素值与 base 相同,则增加 count;否则,重置 count 为 1,并更新 base 为当前元素值。接着,根据 countmaxCount 的关系,更新 maxCount 以及众数列表 answer

整个算法利用了二叉搜索树(BST)的中序遍历特性(遍历结果是升序序列),结合一个简单的计数逻辑来找出出现频率最高的元素。通过遍历过程中维护当前元素的出现次数以及最大出现次数,最终收集到所有的众数并返回。

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

方法一:递归

class Solution {private TreeNode ans;public Solution() {this.ans = null;}private boolean dfs(TreeNode root, TreeNode p, TreeNode q) {if (root == null) return false;boolean lson = dfs(root.left, p, q);boolean rson = dfs(root.right, p, q);if ((lson && rson) || ((root.val == p.val || root.val == q.val) && (lson || rson))) {ans = root;} return lson || rson || (root.val == p.val || root.val == q.val);}public TreeNode lowestCommonAncestor(TreeNode root, TreeNode p, TreeNode q) {this.dfs(root, p, q);return this.ans;}
}

这段代码定义了一个名为 Solution 的类,用于求解二叉树中两个指定节点的最近公共祖先(Lowest Common Ancestor, LCA)。类中包含一个成员变量 ans 用于存储找到的最近公共祖先节点,以及几个方法:

  1. 构造方法 Solution():初始化成员变量 ansnull
  2. 私有方法 dfs(TreeNode root, TreeNode p, TreeNode q):这是一个深度优先搜索(Depth First Search, DFS)方法,用于递归遍历二叉树,同时检查当前节点是否为节点 pq 的祖先。它返回一个布尔值,指示以 root 为根的子树中是否包含 pq
    • 如果 root 为空,返回 false,表示该子树不包含 pq
    • 递归遍历左子树和右子树,获取它们是否包含 pq 的信息。
    • 如果当前节点的左子树和右子树中都包含了 pq,或者当前节点是 pq 之一,并且其子树中也包含另一个节点,那么将当前节点设置为 ans,即最近公共祖先。
    • 最后,返回当前子树是否包含 pq(通过 lsonrson 或当前节点值与 pq 相等判断)。
  3. 公共方法 lowestCommonAncestor(TreeNode root, TreeNode p, TreeNode q):这是解决问题的接口方法,接收二叉树的根节点 root 以及需要查找最近公共祖先的两个节点 pq。它通过调用 dfs 方法进行遍历,并返回找到的最近公共祖先节点 ans

总之,这段代码实现了一个在二叉树中寻找两个指定节点最近公共祖先的算法,利用了深度优先搜索和递归的思想。通过遍历树并利用递归返回的信息,能够有效确定并返回最近公共祖先节点。

这篇关于代码随想录-Day21的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1009507

相关文章

HTML5的input标签的`type`属性值详解和代码示例

《HTML5的input标签的`type`属性值详解和代码示例》HTML5的`input`标签提供了多种`type`属性值,用于创建不同类型的输入控件,满足用户输入的多样化需求,从文本输入、密码输入、... 目录一、引言二、文本类输入类型2.1 text2.2 password2.3 textarea(严格

JAVA项目swing转javafx语法规则以及示例代码

《JAVA项目swing转javafx语法规则以及示例代码》:本文主要介绍JAVA项目swing转javafx语法规则以及示例代码的相关资料,文中详细讲解了主类继承、窗口创建、布局管理、控件替换、... 目录最常用的“一行换一行”速查表(直接全局替换)实际转换示例(JFramejs → JavaFX)迁移建

Go异常处理、泛型和文件操作实例代码

《Go异常处理、泛型和文件操作实例代码》Go语言的异常处理机制与传统的面向对象语言(如Java、C#)所使用的try-catch结构有所不同,它采用了自己独特的设计理念和方法,:本文主要介绍Go异... 目录一:异常处理常见的异常处理向上抛中断程序恢复程序二:泛型泛型函数泛型结构体泛型切片泛型 map三:文

MyBatis中的两种参数传递类型详解(示例代码)

《MyBatis中的两种参数传递类型详解(示例代码)》文章介绍了MyBatis中传递多个参数的两种方式,使用Map和使用@Param注解或封装POJO,Map方式适用于动态、不固定的参数,但可读性和安... 目录✅ android方式一:使用Map<String, Object>✅ 方式二:使用@Param

SpringBoot实现图形验证码的示例代码

《SpringBoot实现图形验证码的示例代码》验证码的实现方式有很多,可以由前端实现,也可以由后端进行实现,也有很多的插件和工具包可以使用,在这里,我们使用Hutool提供的小工具实现,本文介绍Sp... 目录项目创建前端代码实现约定前后端交互接口需求分析接口定义Hutool工具实现服务器端代码引入依赖获

利用Python在万圣节实现比心弹窗告白代码

《利用Python在万圣节实现比心弹窗告白代码》:本文主要介绍关于利用Python在万圣节实现比心弹窗告白代码的相关资料,每个弹窗会显示一条温馨提示,程序通过参数方程绘制爱心形状,并使用多线程技术... 目录前言效果预览要点1. 爱心曲线方程2. 显示温馨弹窗函数(详细拆解)2.1 函数定义和延迟机制2.2

Springmvc常用的注解代码示例

《Springmvc常用的注解代码示例》本文介绍了SpringMVC中常用的控制器和请求映射注解,包括@Controller、@RequestMapping等,以及请求参数绑定注解,如@Request... 目录一、控制器与请求映射注解二、请求参数绑定注解三、其他常用注解(扩展)四、注解使用注意事项一、控制

C++简单日志系统实现代码示例

《C++简单日志系统实现代码示例》日志系统是成熟软件中的一个重要组成部分,其记录软件的使用和运行行为,方便事后进行故障分析、数据统计等,:本文主要介绍C++简单日志系统实现的相关资料,文中通过代码... 目录前言Util.hppLevel.hppLogMsg.hppFormat.hppSink.hppBuf

VS Code中的Python代码格式化插件示例讲解

《VSCode中的Python代码格式化插件示例讲解》在Java开发过程中,代码的规范性和可读性至关重要,一个团队中如果每个开发者的代码风格各异,会给代码的维护、审查和协作带来极大的困难,这篇文章主... 目录前言如何安装与配置使用建议与技巧如何选择总结前言在 VS Code 中,有几款非常出色的 pyt

利用Python将PDF文件转换为PNG图片的代码示例

《利用Python将PDF文件转换为PNG图片的代码示例》在日常工作和开发中,我们经常需要处理各种文档格式,PDF作为一种通用且跨平台的文档格式,被广泛应用于合同、报告、电子书等场景,然而,有时我们需... 目录引言为什么选择 python 进行 PDF 转 PNG?Spire.PDF for Python