问题
给定一个二叉树和一个目标和,判断该树中是否存在根节点到叶子节点的路径,这条路径上所有节点值相加等于目标和。
例子
思路
如果该结点为空,返回false
如果当前结点是叶子结点,返回sums==root.val?
如果当前结点不是叶子结点,让sums-root.val,然后递归调用该方法
代码
/**
* Definition for a binary tree node.
* public class TreeNode {
* int val;
* TreeNode left;
* TreeNode right;
* TreeNode(int x) { val = x; }
* }
*/
class Solution {
public boolean hasPathSum(TreeNode root, int sums) {
if (root==null) return false;
if (root.left==null && root.right==null)
return sums==root.val;
return hasPathSum(root.left, sums-root.val) || hasPathSum(root.right, sums-root.val);
}
}
# Definition for a binary tree node.
# class TreeNode:
# def __init__(self, x):
# self.val = x
# self.left = None
# self.right = None
class Solution:
def hasPathSum(self, root: TreeNode, sums: int) -> bool:
if root is None: return False
#是否为叶节点
if root.left is None and root.right is None:
return sums==root.val
return self.hasPathSum(root.left, sums-root.val) or self.hasPathSum(root.right, sums-root.val)