class Solution(object): def hasPathSum(self, root, sum): """ :type root: TreeNode :type sum: int :rtype: bool """ if root == None: return False if root.left == None and root.right == None: return sum == root.val return self.hasPathSum(root.left, sum - root.val) or self.hasPathSum(root.right, sum - root.val)
总结
题目要求的和必须是一直贯穿到最下面的叶子结点。不需要考虑中间就到达和的情况
这种题目的递归结构都十分相似,通过这种结构来遍历到整个树。
1
self.hasPathSum(root.left, sum - root.val) or self.hasPathSum(root.right, sum - root.val)