112. 路径总和

描述 :

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

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

题目 :

LeetCode 112.路径总和 :

112. 路径总和

分析 :

这题和上面的题差不多 , 需要一个变量记录从根节点到叶子节点的总和 , 如果是叶子节点就判断否则就累加 .

不难发现这题满足递归的性质,若当前节点就是叶子节点,那么我们直接判断 sum 是否等于 val 即(因为路径和已经确定,就是当前节点的值,我们只需要判断该路径和是否满足条件)。若当前节点不是叶子节点,我们只需要递归地询问它的子节点是否能满足条件即可。

解析 :

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) {
        return allNum(root,0,targetSum);
    }
    public boolean allNum(TreeNode root,int num,int targetSum){
        if(root == null){
            return false;
        }
        if(root.left == null && root.right == null){
            num += root.val;
            if(targetSum == num){
                return true;
            }
            return false;
        }
        num += root.val;
        boolean p = allNum(root.left,num,targetSum);
        boolean q =allNum(root.right,num,targetSum);
        return p || q;
    }
}

这期就到这里 , 下期见!

相关推荐
mit6.8241 小时前
Xai架构
算法
WBluuue1 小时前
Codeforces 1078 Div2(ABCDEF1)
c++·算法
寻星探路2 小时前
【JVM 终极通关指南】万字长文从底层到实战全维度深度拆解 Java 虚拟机
java·开发语言·jvm·人工智能·python·算法·ai
田里的水稻2 小时前
FA_融合和滤波(FF)-联邦滤波(FKF)
人工智能·算法·数学建模·机器人·自动驾驶
紫陌涵光2 小时前
112. 路径总和
java·前端·算法
回敲代码的猴子2 小时前
2月8日上机
开发语言·c++·算法
IT猿手3 小时前
MOEA/D(基于分解的多目标进化算法)求解46个多目标函数及一个工程应用,包含四种评价指标,MATLAB代码
开发语言·算法·matlab·多目标算法
Benny_Tang3 小时前
AtCoder Beginner Contest 445(ABC445) A-F 题解
c++·算法
sprintzer3 小时前
2.06-2.15力扣数学刷题
算法·leetcode·职场和发展
喵呜嘻嘻嘻4 小时前
Gurobi求解器参数
java·数据结构·算法