news 2026/6/12 0:13:50

力扣刷题:路径总和

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
力扣刷题:路径总和

题目:
给你二叉树的根节点 root 和一个表示目标和的整数 targetSum 。判断该树中是否存在 根节点到叶子节点 的路径,这条路径上所有节点值相加等于目标和 targetSum 。如果存在,返回 true ;否则,返回 false 。

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

示例 1:

输入:root = [5,4,8,11,null,13,4,7,2,null,null,null,1], targetSum = 22
输出:true
解释:等于目标和的根节点到叶节点路径如上图所示。
示例 2:

输入:root = [1,2,3], targetSum = 5
输出:false
解释:树中存在两条根节点到叶子节点的路径:
(1 --> 2): 和为 3
(1 --> 3): 和为 4
不存在 sum = 5 的根节点到叶子节点的路径。
示例 3:

输入:root = [], targetSum = 0
输出:false
解释:由于树是空的,所以不存在根节点到叶子节点的路径。

解析:
这道题使用dfs+回溯来解决:

使用深度优先搜索遍历所有可能的路径,在遍历过程中:
从根节点开始,记录当前路径的累加和
到达叶子节点时,检查路径和是否等于目标值
找到一条符合条件的路径就立即返回

如何表示路径和?
从目标值开始,每经过一个节点就减去其值,检查是否减到0

递归终止条件是什么?
到达叶子节点时,判断剩余值是否为0
如果当前节点为空,返回false

如何遍历所有路径?
对每个非叶子节点,分别探索其左子树和右子树
使用递归进行深度优先搜索
具体代码:

/** * @param {TreeNode} root * @param {number} targetSum * @return {boolean} */varhasPathSum=function(root,targetSum){// 1. 处理空树的情况:空树没有路径,直接返回falseif(!root)returnfalse// 2. 从根节点开始遍历,初始sum = targetSum - 根节点值// 因为根节点的值已经计入路径和了returntraversal(root,targetSum-root.val)};functiontraversal(node,sum){// 3. 终止条件1:到达叶子节点,且剩余sum为0// sum === 0 表示路径和正好等于targetSum// !node.left && !node.right 确保是叶子节点if(sum===0&&!node.left&&!node.right)returntrue// 4. 终止条件2:到达叶子节点,但剩余sum不为0// 说明这条路径的和不等于targetSumif(sum!==0&&!node.left&&!node.right)returnfalse// 5. 递归处理左子树if(node.left){// 5.1 做出选择:将左子节点的值从sum中减去sum-=node.left.val// 5.2 递归探索左子树if(traversal(node.left,sum)){returntrue// 如果左子树找到符合条件的路径,直接返回true}// 5.3 撤销选择(回溯):恢复sum的值// 因为要尝试右子树,需要回到之前的状态sum+=node.left.val}// 6. 递归处理右子树if(node.right){// 6.1 做出选择:将右子节点的值从sum中减去sum-=node.right.val// 6.2 递归探索右子树if(traversal(node.right,sum)){returntrue// 如果右子树找到符合条件的路径,直接返回true}// 6.3 撤销选择(回溯):恢复sum的值sum+=node.right.val}// 7. 左右子树都没有找到符合条件的路径,返回falsereturnfalse}
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/2 21:32:20

从规划到监控:PMP方法论赋能低代码流程优化风险管理

在我们利用低代码平台做流程优化实施的时候,很常见的一个场景是需要把一些线下的流程搬到线上,其中比较典型就是审批流程的线上化,以和某个企业合作为例,该企业原采购审批依赖纸质单据和邮件,审批周期长达5天&#xff…

作者头像 李华
网站建设 2026/6/11 19:55:48

PyTorch从环境配置到GPU加速完整笔记

PyTorch实战全栈指南:从零搭建高效训练流水线 在深度学习项目中,一个稳定、高效的开发环境和清晰的训练流程是成功复现模型与快速迭代的关键。很多初学者在使用PyTorch时常常卡在“明明代码没错,却跑不起来”——可能是环境冲突、数据格式不…

作者头像 李华
网站建设 2026/6/2 18:07:25

PyTorch GPU利用率低?提速训练的8大实用技巧

PyTorch GPU利用率低?提速训练的8大实用技巧 在使用 PyTorch 训练深度学习模型时,你是否经历过这样的场景:显存已经快爆了,nvidia-smi 却显示 GPU 利用率长期卡在 10%~30%,甚至更低?看着 A100 这样的“算力…

作者头像 李华
网站建设 2026/6/9 13:47:59

错过再等十年:智普Open-AutoGLM核心原理首次公开解读

第一章:错过再等十年:智普Open-AutoGLM核心原理首次公开解读智普AI最新发布的Open-AutoGLM模型,标志着自动化自然语言处理迈向新纪元。该模型融合了图神经网络与大语言模型的双重优势,能够在无监督场景下自动构建知识图谱并完成复…

作者头像 李华
网站建设 2026/6/11 17:22:06

OpenCV4 Python GPU加速YOLOv3目标检测实战

OpenCV4 Python GPU加速YOLOv3目标检测实战 在实时视频分析、智能监控和自动驾驶等场景中,“快”从来不只是一个性能指标,而是系统能否落地的关键门槛。哪怕模型精度再高,如果单帧处理耗时超过几十毫秒,整个系统就会因为延迟累积…

作者头像 李华
网站建设 2026/6/10 21:06:52

梯度下降法:优化算法核心解析

梯度下降法:优化算法核心解析 在一张泛黄的老照片上,斑驳的灰度影像记录着百年前的一次家庭聚会。人物轮廓依稀可辨,但衣着的颜色、背景的景致早已湮没在时光中。如今,只需几秒,AI就能为这张黑白照“还原”出近乎真实…

作者头像 李华