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

这期就到这里 , 下期见!

相关推荐
HelloDam17 分钟前
基于元素小组的归并排序算法
后端·算法·排序算法
HelloDam17 分钟前
基于连贯性算法的多边形扫描线生成(适用于凸多边形和凹多边形)【原理+java实现】
算法
uhakadotcom1 小时前
Apache Airflow入门指南:数据管道的强大工具
算法·面试·github
跳跳糖炒酸奶2 小时前
第四章、Isaacsim在GUI中构建机器人(2):组装一个简单的机器人
人工智能·python·算法·ubuntu·机器人
绵绵细雨中的乡音2 小时前
动态规划-第六篇
算法·动态规划
程序员黄同学2 小时前
动态规划,如何应用动态规划解决实际问题?
算法·动态规划
march_birds2 小时前
FreeRTOS 与 RT-Thread 事件组对比分析
c语言·单片机·算法·系统架构
斯汤雷3 小时前
Matlab绘图案例,设置图片大小,坐标轴比例为黄金比
数据库·人工智能·算法·matlab·信息可视化
云 无 心 以 出 岫3 小时前
贪心算法QwQ
数据结构·c++·算法·贪心算法
俏布斯4 小时前
算法日常记录
java·算法·leetcode