112、Path Sum

2018-08-06  本文已影响0人  小碧小琳

可以按照前序遍历的顺序遍历树,在遍历过程中,定义一个变量,
这个变量等于sum减去已经被遍历过的所有节点的val。一直到叶节点时,若是这个叶节点等于这个sum,就说明书中存在这样一个路径。

树的遍历,想到了递归函数,于是调用递归函数。

# 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, sum):
        """
        :type root: TreeNode
        :type sum: int
        :rtype: bool
        """

        if root == None:
            return False
        if root.left == None and root.right == None and root.val == sum:
            return True
        #有一个为正确的,那就是正确
        return self.hasPathSum(root.left,sum-root.val) or self.hasPathSum(root.right,sum-root.val)

上一篇 下一篇

猜你喜欢

热点阅读