【leetcode】112.路径总和

【leetcode】112.路径总和


在这里插入图片描述

题目

leetcode原题链接

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

示例 1:
image-20220427090755564
输入: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
解释:由于树是空的,所以不存在根节点到叶子节点的路径。

提示:
树中节点的数目在范围 [0, 5000] 内
-1000 <= Node.val <= 1000
-1000 <= targetSum <= 1000

思路

在这里插入图片描述

  • 首先是遍历二叉树的方式,这里使用前序遍历。
  • 使用递归方式来做,分析如下:
    • 递归函数的参数是当前节点以及目前的路径和(包含当前节点的值),返回值就是true或false
    • 返回条件:当遇到叶子节点时判断路径和是否等于目标和,是的话返回true,否则返回false。
    • 单层递归的逻辑:如果左右节点存在,就递归左右节点,并且判断递归返回值,如果返回值为true就直接返回true,这一步保证了当遇到满足条件的一条路径时就结束了二叉树的遍历,而不是遍历整一棵二叉树。

代码

在这里插入图片描述

var hasPathSum = function(root, targetSum) {
    function traversal(node , sum){
        // 遇到叶子节点且路径和等于目标和
        if(!node.left && !node.right && sum === targetSum) return true
        if(!node.left && !node.right) return false

        if(node.left && traversal(node.left , sum + node.left.val)) return true
        if(node.right && traversal(node.right , sum + node.right.val)) return true
        return false
    }

    if(!root) return false 
    return traversal(root , root.val)
};

精简一下代码

var hasPathSum = function(root, targetSum) {
    if(!root) return false
    if(!root.left && !root.right && root.val === targetSum) return true
    return hasPathSum(root.left , targetSum - root.val) || hasPathSum(root.right , targetSum - root.val)
};

关注我的专栏,每天更新三道leetcode题解,一起变强!

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

前端corner

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值