LeetCode题练习与总结:路径总和Ⅱ--113

一、题目描述

给你二叉树的根节点 root 和一个整数目标和 targetSum ,找出所有 从根节点到叶子节点 路径总和等于给定目标和的路径。

叶子节点 是指没有子节点的节点。

示例 1:

输入:root = [5,4,8,11,null,13,4,7,2,null,null,5,1], targetSum = 22
输出:[[5,4,11,2],[5,8,4,5]]

示例 2:

输入:root = [1,2,3], targetSum = 5
输出:[]

示例 3:

输入:root = [1,2], targetSum = 0
输出:[]

提示:

  • 树中节点总数在范围 [0, 5000] 内
  • -1000 <= Node.val <= 1000
  • -1000 <= targetSum <= 1000

二、解题思路

这个问题可以通过递归的方式解决。我们定义一个递归函数,该函数接受当前节点和当前路径和作为参数。递归函数的工作流程如下:

1. 如果当前节点是空,返回一个空列表。

2. 如果当前节点是叶子节点(即没有子节点),检查当前路径和是否等于目标值。如果是,将当前路径和加入到结果列表中。

3. 如果当前节点不是叶子节点,递归地调用函数:

  • 调用函数,参数是当前节点的左子节点和当前路径和加上当前节点的值。
  • 调用函数,参数是当前节点的右子节点和当前路径和加上当前节点的值。

4. 将两个递归调用中的结果合并到一起,并返回。

三、具体代码

class Solution {public List<List<Integer>> pathSum(TreeNode root, int targetSum) {List<List<Integer>> result = new ArrayList<>();if (root == null) {return result;}pathSum(root, targetSum, new ArrayList<>(), result);return result;}private void pathSum(TreeNode node, int target, List<Integer> currentPath, List<List<Integer>> result) {if (node == null) {return;}currentPath.add(node.val);if (node.left == null && node.right == null && target == node.val) {result.add(new ArrayList<>(currentPath));}pathSum(node.left, target - node.val, currentPath, result);pathSum(node.right, target - node.val, currentPath, result);currentPath.remove(currentPath.size() - 1);}
}

四、时间复杂度和空间复杂度

1. 时间复杂度
  • 递归函数调用次数:对于每个节点,我们最多会调用一次 pathSum 函数。因此,对于一个有 n 个节点的树,最坏情况下,函数会被调用 n 次。

  • 单次递归调用的时间复杂度:对于每个节点的单次递归调用,我们需要执行常数时间操作,如判断当前节点是否为空、更新当前路径、判断是否为叶子节点以及添加结果等。

  • 综上所述,总的时间复杂度是 O(n),其中 n 是树中节点的数量。
2. 空间复杂度
  • 递归调用栈:递归调用会使用系统栈来存储每一层递归的信息。在最坏的情况下,树可能是一个完全二叉树,此时递归调用栈的深度为 O(h),其中 h 是树的高度。

  • 其他空间:除了递归调用栈之外,我们不需要额外的空间来存储节点的信息,因此这部分的空间复杂度是 O(1)。

  • 综上所述,总的空间复杂度是 O(h),在最坏情况下是 O(n)。

五、总结知识点

  1. 递归函数pathSum 函数是一个递归函数,它接受当前节点、目标和当前路径作为参数,并递归地检查左子树和右子树。

  2. 二叉树的遍历:通过递归的方式,代码实现了对二叉树的遍历,从根节点开始,逐层向下,直到到达叶子节点。

  3. 路径和的概念:代码中维护了一个变量 currentPath,用于跟踪从根节点到当前节点的路径上所有节点值之和。

  4. 叶子节点的判断:通过检查当前节点的左右子节点是否都为空来确定一个节点是否是叶子节点。

  5. 条件语句:代码中使用了 if 条件语句来判断节点是否为空、是否为叶子节点以及路径和是否等于目标值。

  6. 递归终止条件:递归函数在遇到空节点时返回,这是递归的终止条件。

  7. 逻辑运算符:代码中使用了逻辑运算符 || 来组合两个递归调用,如果任意一个调用返回 true,则整个表达式返回 true。

  8. 函数的封装pathSum 函数被定义为 private,这意味着它只能在同一个类中被访问,这是封装的一种形式。

  9. 树的表示:代码中使用了 TreeNode 类来定义二叉树的节点,这是二叉树数据结构的基本表示方法。

  10. 列表的使用:代码中使用了 ArrayList 类来存储路径和结果,这是一种动态数组,可以方便地添加和删除元素。

以上就是解决这个问题的详细步骤,希望能够为各位提供启发和帮助。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/pingmian/20630.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

FreeRTOS同步互斥与通信

本章简介&#xff1a; 本章是概述性的内容。可以把多任务系统当做一个团队&#xff0c;里面的每一个任务就相当于团队里的一个人。团队成员之间要协调工作进度(同步)、争用会议室(互斥)、沟通(通信)。多任务系统中所涉及的概念&#xff0c;都可以在现实生活中找到例子。 各类RT…

Java大厂面试题第2季

一、本课程前提要求和说明 面试题1&#xff1a; 面试题2&#xff1a; 面试题3&#xff1a; 面试题4&#xff1a; 面试题5&#xff1a; 高频最多的常见笔试面试题目 ArrayList HashMap 底层是什么东东 JVM/GC 多线程与高并发 java集合类

【科研基础】证明积累

1-Bayesian Estimation (P317) Suppose that x = θ + ν w h e r e ν i s a n N ( 0 , σ ) random variable and θ is the value of a n N ( θ 0 , σ 0 ) random variable θ (Fig. 8-7). Find the bayesian estimate θ o f θ . \begin{align…

大学校园广播“录编播”与IP校园公共广播系统技术方案

一、项目概述 1、校园IP网络广播系统概述 大学校园广播系统是学校整个弱电系统中的子系统&#xff0c;它是每个学校不可缺少的基础设施之一&#xff0c;在传递校园文化、传播校园新闻资讯方面发挥着重要的作用。近几年来&#xff0c;虽然视频技术和网络技术在飞速发展&#xf…

操作系统的体系结构:宏内核和微内核

操作系统的体系结构是一个开放的问题。操作系统在核心态为应用程序提供公共的服务&#xff0c;那么操作系统在核心态应该提供什么服务、怎样提供服务&#xff1f;有关这个问题的回答形成了两种主要的体系结构&#xff1a;宏内核和微内核。 宏内核&#xff1a;大而全 宏内核系统…

2024蓝桥杯国赛C++研究生组游记+个人题解

Day0 开始复习&#xff0c;过了一遍大部分板子 本来打算再学一遍SAM&#xff0c;但是想到去年考了字符串大题今年应该不会再考了吧。。 过了一遍数据结构和图论&#xff0c;就1点了 两点的时候还没睡着&#xff0c;舍友打游戏好像打到2点过。。 Day1 相当困 第一题&…

word里面没有Acrobat选项

加载项被禁止&#xff0c;选择项里面&#xff0c;没有Acrobat选项 文件-》选项 加载项-》com加载项-》转到 添加Acrobat 出现Acrobat选项

[Qt]关于QListWidget、QScrollArea 为什么在QDesigner上设置了之后界面上仍然不生效的问题

前言 最近做了一些有关QListWidget和QScrollArea的控件&#xff0c;我去&#xff0c;这两个控件是真的坑&#xff0c;明明我在QDesigner的操作界面上对这两个控件的界面进行了修改&#xff0c;但是编译出来的软件就是看上去什么都没有&#xff0c;很坑&#xff0c;Gpt也没解决…

【linux】宝塔,首页挂载磁盘,显示使用情况

挂载前&#xff1a; 挂载后&#xff1a; 数据无价&#xff0c;建议&#xff1a;备份需要挂载的磁盘&#xff0c;或者使用新磁盘来进行操作。 1、下载自动挂载磁盘的脚本&#xff1a; wget -O auto_disk.sh http://download.bt.cn/tools/auto_disk.sh 2、给脚本添加执行权限&a…

Re0:从零开始的C++游戏开发 【下】

Re0:从零开始的C游戏开发 &#xff08;下&#xff09; 这是蒟蒻观看B站upVoidmatrix的课程从零开始的提瓦特幸存者的个人笔记【自用】 前言&#xff1a;采用适用于小白的easyx图形库。 第三集 提瓦特の幸存者&#xff08;下&#xff09; 3.1 用户界面实现和设计模式基础 3…

省级交通运输行政执法综合管理平台项目实施方案

背景 党的十八届四中全会提出全面推进依法治国的总目标和重大任务。全会通过的《中共中央关于全面推进依法治国若干重大问题的决定》&#xff0c;开启了中国法治建设的新时代&#xff0c;依法治国已经成为党领导人民治理国家的基本方略。 为了贯彻和落实《交通运输信息化“十三…

资深人士称:AI开发游戏会降低游戏成本和体验,不会降低就业率

易采游戏网6月1日最新消息&#xff1a;本周在TD Cowen会议上&#xff0c;R星的母公司Take-Two的CEO Strauss Zelnick对于人工智能(AI)是否会影响游戏开发行业表达了自己的看法。他坚定地认为&#xff0c;AI绝对会改变游戏的制作方式&#xff0c;但不会降低游戏行业的就业水平。…

Maven打包错误:无效的源发行版:17

1. 报错问题 在用maven进行打包时&#xff08;clean & install&#xff09;&#xff0c;报如下错误&#xff1a; 一开始让我很摸不着头脑&#xff0c;我确定我的pom.xml&#xff0c;还有IDEA中的Project Settings是正确的。 2. 排查 尽管确定&#xff0c;但还是一个个排…

秒杀基本功能开发(显示商品列表和商品详情)

文章目录 1.数据库表设计1.商品表2.秒杀商品表3.修改一下秒杀时间为今天到明天 2.pojo和vo编写1.com/sxs/seckill/pojo/Goods.java2.com/sxs/seckill/pojo/SeckillGoods.java3.com/sxs/seckill/vo/GoodsVo.java 3.Mapper编写1.GoodsMapper.java2.GoodsMapper.xml3.分别编写Seck…

在浏览器里面输入 url,到浏览器显示页面中间发生了什么?

当用户在浏览器中输入URL&#xff08;例如https://www.example.com&#xff09;按下回车键&#xff0c;到浏览器显示页面&#xff0c;这中间浏览器会执行以下步骤&#xff1a; 浏览器解析URL&#xff1a;浏览器解析URL&#xff0c;提取出协议&#xff08;如HTTP或HTTPS&#xf…

每天一个数据分析题(三百四十二)

根据量化对象是业务行为结果还是财务行为结果&#xff0c;可以将指标分为业务指标及财务指标两大类&#xff0c;以下说法正确的是&#xff1f; A. 财务指标是按照财务规则来对财务情况进行量化的指标 B. 业务指标是按照业务规则来对业务情况进行量化的指标 C. 业务指标需要按…

VS(visual studio)搭建QT开发环境插件安装

优先安装QT Qt6 官网QtCreator 下载与安装方法win10_qt6下载-CSDN博客 如果安装vs2019,打开installer,安装c环境 选择c 下载vsix后&#xff0c;双击安装即可。 插件下载&#xff1a; Index of /qtproject/official_releases/vsaddin/ 创建QT项目&#xff1a; 创建完成&…

4K高刷显示器 - 蚂蚁电竞ANT27VU

可以毫不夸张地说&#xff0c;每一局游戏最终能够取得胜利&#xff0c;实际上都与一套极为优秀的电竞 PC 有着紧密的关联&#xff0c;因为其能够提供强大的性能支持与流畅的体验。同样的道理&#xff0c;一套优秀的电竞 PC 若想发挥出最佳的效果&#xff0c;那也都离不开一台能…

leetCode-hot100-数组专题之求和+数学定理+其他

数组专题之求和数学定理其他 求和1.两数之和15.三数之和 数学定理169.多数元素 其他4.寻找两个正序数组的中位数128.最长连续序列 求和 数组求和问题&#xff0c;即计算数组中所有元素的总和&#xff0c;是编程中常见的任务。以下是一些常用的解决方法&#xff1a; 1. 循环遍历…

介绍一下js的节流与防抖

在JavaScript中&#xff0c;节流&#xff08;Throttling&#xff09;和防抖&#xff08;Debouncing&#xff09;是两种常用的优化高频率触发事件的策略。它们主要用于限制函数的执行频率&#xff0c;以避免因频繁触发导致的性能问题。 1. 防抖&#xff08;Debouncing&#xff…