代码随想录-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

相关文章

Java进行日期解析与格式化的实现代码

《Java进行日期解析与格式化的实现代码》使用Java搭配ApacheCommonsLang3和Natty库,可以实现灵活高效的日期解析与格式化,本文将通过相关示例为大家讲讲具体的实践操作,需要的可以... 目录一、背景二、依赖介绍1. Apache Commons Lang32. Natty三、核心实现代

使用Python自动化生成PPT并结合LLM生成内容的代码解析

《使用Python自动化生成PPT并结合LLM生成内容的代码解析》PowerPoint是常用的文档工具,但手动设计和排版耗时耗力,本文将展示如何通过Python自动化提取PPT样式并生成新PPT,同时... 目录核心代码解析1. 提取 PPT 样式到 jsON关键步骤:代码片段:2. 应用 JSON 样式到

SpringBoot实现二维码生成的详细步骤与完整代码

《SpringBoot实现二维码生成的详细步骤与完整代码》如今,二维码的应用场景非常广泛,从支付到信息分享,二维码都扮演着重要角色,SpringBoot是一个非常流行的Java基于Spring框架的微... 目录一、环境搭建二、创建 Spring Boot 项目三、引入二维码生成依赖四、编写二维码生成代码五

使用Python和PaddleOCR实现图文识别的代码和步骤

《使用Python和PaddleOCR实现图文识别的代码和步骤》在当今数字化时代,图文识别技术的应用越来越广泛,如文档数字化、信息提取等,PaddleOCR是百度开源的一款强大的OCR工具包,它集成了... 目录一、引言二、环境准备2.1 安装 python2.2 安装 PaddlePaddle2.3 安装

SpringBoot中四种AOP实战应用场景及代码实现

《SpringBoot中四种AOP实战应用场景及代码实现》面向切面编程(AOP)是Spring框架的核心功能之一,它通过预编译和运行期动态代理实现程序功能的统一维护,在SpringBoot应用中,AO... 目录引言场景一:日志记录与性能监控业务需求实现方案使用示例扩展:MDC实现请求跟踪场景二:权限控制与

利用Python调试串口的示例代码

《利用Python调试串口的示例代码》在嵌入式开发、物联网设备调试过程中,串口通信是最基础的调试手段本文将带你用Python+ttkbootstrap打造一款高颜值、多功能的串口调试助手,需要的可以了... 目录概述:为什么需要专业的串口调试工具项目架构设计1.1 技术栈选型1.2 关键类说明1.3 线程模

Python Transformers库(NLP处理库)案例代码讲解

《PythonTransformers库(NLP处理库)案例代码讲解》本文介绍transformers库的全面讲解,包含基础知识、高级用法、案例代码及学习路径,内容经过组织,适合不同阶段的学习者,对... 目录一、基础知识1. Transformers 库简介2. 安装与环境配置3. 快速上手示例二、核心模

Java的栈与队列实现代码解析

《Java的栈与队列实现代码解析》栈是常见的线性数据结构,栈的特点是以先进后出的形式,后进先出,先进后出,分为栈底和栈顶,栈应用于内存的分配,表达式求值,存储临时的数据和方法的调用等,本文给大家介绍J... 目录栈的概念(Stack)栈的实现代码队列(Queue)模拟实现队列(双链表实现)循环队列(循环数组

使用Java将DOCX文档解析为Markdown文档的代码实现

《使用Java将DOCX文档解析为Markdown文档的代码实现》在现代文档处理中,Markdown(MD)因其简洁的语法和良好的可读性,逐渐成为开发者、技术写作者和内容创作者的首选格式,然而,许多文... 目录引言1. 工具和库介绍2. 安装依赖库3. 使用Apache POI解析DOCX文档4. 将解析

C++使用printf语句实现进制转换的示例代码

《C++使用printf语句实现进制转换的示例代码》在C语言中,printf函数可以直接实现部分进制转换功能,通过格式说明符(formatspecifier)快速输出不同进制的数值,下面给大家分享C+... 目录一、printf 原生支持的进制转换1. 十进制、八进制、十六进制转换2. 显示进制前缀3. 指