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;
    }
}

这期就到这里 , 下期见!

相关推荐
清酒难咽7 分钟前
算法案例之递归
c++·经验分享·算法
让我上个超影吧25 分钟前
【力扣26&80】删除有序数组中的重复项
算法·leetcode
张张努力变强1 小时前
C++ Date日期类的设计与实现全解析
java·开发语言·c++·算法
沉默-_-2 小时前
力扣hot100滑动窗口(C++)
数据结构·c++·学习·算法·滑动窗口
钱彬 (Qian Bin)2 小时前
项目实践19—全球证件智能识别系统(优化检索算法:从MobileNet转EfficientNet)
算法·全球证件识别
feifeigo1232 小时前
基于EM算法的混合Copula MATLAB实现
开发语言·算法·matlab
漫随流水2 小时前
leetcode回溯算法(78.子集)
数据结构·算法·leetcode·回溯算法
IT猿手2 小时前
六种智能优化算法(NOA、MA、PSO、GA、ZOA、SWO)求解23个基准测试函数(含参考文献及MATLAB代码)
开发语言·算法·matlab·无人机·无人机路径规划·最新多目标优化算法
We་ct3 小时前
LeetCode 151. 反转字符串中的单词:两种解法深度剖析
前端·算法·leetcode·typescript
芜湖xin3 小时前
【题解-Acwing】AcWing 5579. 增加模数(TLE)
算法·快速幂