112题路径总和
给你二叉树的根节点 root
和一个表示目标和的整数 targetSum
。判断该树中是否存在 根节点到叶子节点 的路径,这条路径上所有节点值相加等于目标和 targetSum
。如果存在,返回 true
;否则,返回 false
。
叶子节点 是指没有子节点的节点。
看了题解之后做出来的
思路就是采用dfs深度优先算法,一直向下找到叶子节点,判断是否=targetSum
是就返回true,不是就返回false;
ps:如果root=null,返回false;
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;
}
if(root.left==null&&root.right==null)
{
if(targetSum==root.val)
{
return true;
}
}
return hasPathSum(root.left,targetSum-root.val) || hasPathSum(root.right,targetSum-root.val);
}
}