跟着小码学算法Day19:路径总和

一、算法思想:递归+回溯

1. 递归(DFS 深度优先搜索)

核心思想:

  • 从根开始,每往下走一层,就从 targetSum 中减去当前节点的值。
  • 到达叶子节点时,检查剩余的 targetSum 是否等于 0。
  • 如果等于 0,说明找到了一条满足条件的路径。

2. 递推方式(减法思想)

我们不维护路径和,而是不断 缩小目标值

复制代码
newTarget = targetSum - root.val

然后递归地在子树中查找是否存在和为 newTarget 的路径。

口诀: "递归减目标,叶节点判零,左右任一真,整体就为真。"


二、解题模板

java 复制代码
public boolean hasPathSum(TreeNode root, int targetSum) {
    // 空节点,无路径
    if (root == null) {
        return false;
    }

    // 到达叶子节点,判断剩余目标是否等于当前节点值
    if (root.left == null && root.right == null) {
        return targetSum == root.val;
    }

    // 递归检查左子树或右子树
    return hasPathSum(root.left, targetSum - root.val) ||
           hasPathSum(root.right, targetSum - root.val);
}

三、典型例题

112. 路径总和 - 力扣(LeetCode)

java 复制代码
/**
 * Definition for a binary tree node.
 * public class TreeNode {
 *     int val;
 *     TreeNode left;
 *     TreeNode right;
 *     TreeNode() {}
 *     TreeNode(int val) { this.val = val; }
 *     TreeNode(int val, TreeNode left, TreeNode right) {
 *         this.val = val;
 *         this.left = left;
 *         this.right = right;
 *     }
 * }
 */
class Solution {
    public boolean hasPathSum(TreeNode root, int targetSum) {
        if(root==null){
            return false;
        }
        targetSum-=root.val;

        if(root.left==null && root.right==null){
            return targetSum==0;
        }

        if(root.left!=null){
            boolean left = hasPathSum(root.left,targetSum);
            if(left){
                return true;
            }
        }
        if(root.right!=null){
            boolean right = hasPathSum(root.right,targetSum);
            if(right){
                return true;
            }
        }

        return false;
    }
}
相关推荐
WL_Aurora2 分钟前
Python 算法基础篇之什么是算法
python·算法
呱牛do it9 分钟前
企业级门户网站设计与实现:基于SpringBoot + Vue3的全栈解决方案(Day 7)
java·vue
墨染天姬9 分钟前
[AI]DeepSeek-R1的GRPO算法
人工智能·算法·php
D_C_tyu12 分钟前
JavaScript | 数独游戏核心算法实现
javascript·算法·游戏
qiqsevenqiqiqiqi13 分钟前
MT2048三连 暴力→数学推导→O (n) 优化
数据结构·c++·算法
NE_STOP16 分钟前
Redis--SDS字符串与集合的底层实现原理
java
码之气三段.20 分钟前
十五届山东ccpc省赛补题(update)
数据结构·c++·算法
直奔標竿20 分钟前
Java开发者AI转型第二十二课!Spring AI 个人知识库实战(一)——架构搭建与核心契约落地
java·人工智能·后端·spring·架构
身如柳絮随风扬22 分钟前
深入理解Java IO与NIO的区别:从BIO到NIO的演进
java·nio
A-Jie-Y1 小时前
JAVA设计模式-抽象工厂模式
java·设计模式