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

相关文章

活用c4d官方开发文档查询代码

当你问AI助手比如豆包,如何用python禁止掉xpresso标签时候,它会提示到 这时候要用到两个东西。https://developers.maxon.net/论坛搜索和开发文档 比如这里我就在官方找到正确的id描述 然后我就把参数标签换过来

poj 1258 Agri-Net(最小生成树模板代码)

感觉用这题来当模板更适合。 题意就是给你邻接矩阵求最小生成树啦。~ prim代码:效率很高。172k...0ms。 #include<stdio.h>#include<algorithm>using namespace std;const int MaxN = 101;const int INF = 0x3f3f3f3f;int g[MaxN][MaxN];int n

计算机毕业设计 大学志愿填报系统 Java+SpringBoot+Vue 前后端分离 文档报告 代码讲解 安装调试

🍊作者:计算机编程-吉哥 🍊简介:专业从事JavaWeb程序开发,微信小程序开发,定制化项目、 源码、代码讲解、文档撰写、ppt制作。做自己喜欢的事,生活就是快乐的。 🍊心愿:点赞 👍 收藏 ⭐评论 📝 🍅 文末获取源码联系 👇🏻 精彩专栏推荐订阅 👇🏻 不然下次找不到哟~Java毕业设计项目~热门选题推荐《1000套》 目录 1.技术选型 2.开发工具 3.功能

代码随想录冲冲冲 Day39 动态规划Part7

198. 打家劫舍 dp数组的意义是在第i位的时候偷的最大钱数是多少 如果nums的size为0 总价值当然就是0 如果nums的size为1 总价值是nums[0] 遍历顺序就是从小到大遍历 之后是递推公式 对于dp[i]的最大价值来说有两种可能 1.偷第i个 那么最大价值就是dp[i-2]+nums[i] 2.不偷第i个 那么价值就是dp[i-1] 之后取这两个的最大值就是d

pip-tools:打造可重复、可控的 Python 开发环境,解决依赖关系,让代码更稳定

在 Python 开发中,管理依赖关系是一项繁琐且容易出错的任务。手动更新依赖版本、处理冲突、确保一致性等等,都可能让开发者感到头疼。而 pip-tools 为开发者提供了一套稳定可靠的解决方案。 什么是 pip-tools? pip-tools 是一组命令行工具,旨在简化 Python 依赖关系的管理,确保项目环境的稳定性和可重复性。它主要包含两个核心工具:pip-compile 和 pip

D4代码AC集

贪心问题解决的步骤: (局部贪心能导致全局贪心)    1.确定贪心策略    2.验证贪心策略是否正确 排队接水 #include<bits/stdc++.h>using namespace std;int main(){int w,n,a[32000];cin>>w>>n;for(int i=1;i<=n;i++){cin>>a[i];}sort(a+1,a+n+1);int i=1

html css jquery选项卡 代码练习小项目

在学习 html 和 css jquery 结合使用的时候 做好是能尝试做一些简单的小功能,来提高自己的 逻辑能力,熟悉代码的编写语法 下面分享一段代码 使用html css jquery选项卡 代码练习 <div class="box"><dl class="tab"><dd class="active">手机</dd><dd>家电</dd><dd>服装</dd><dd>数码</dd><dd

生信代码入门:从零开始掌握生物信息学编程技能

少走弯路,高效分析;了解生信云,访问 【生信圆桌x生信专用云服务器】 : www.tebteb.cc 介绍 生物信息学是一个高度跨学科的领域,结合了生物学、计算机科学和统计学。随着高通量测序技术的发展,海量的生物数据需要通过编程来进行处理和分析。因此,掌握生信编程技能,成为每一个生物信息学研究者的必备能力。 生信代码入门,旨在帮助初学者从零开始学习生物信息学中的编程基础。通过学习常用

husky 工具配置代码检查工作流:提交代码至仓库前做代码检查

提示:这篇博客以我前两篇博客作为先修知识,请大家先去看看我前两篇博客 博客指路:前端 ESlint 代码规范及修复代码规范错误-CSDN博客前端 Vue3 项目开发—— ESLint & prettier 配置代码风格-CSDN博客 husky 工具配置代码检查工作流的作用 在工作中,我们经常需要将写好的代码提交至代码仓库 但是由于程序员疏忽而将不规范的代码提交至仓库,显然是不合理的 所

Unity3D自带Mouse Look鼠标视角代码解析。

Unity3D自带Mouse Look鼠标视角代码解析。 代码块 代码块语法遵循标准markdown代码,例如: using UnityEngine;using System.Collections;/// MouseLook rotates the transform based on the mouse delta./// Minimum and Maximum values can