- 标签:树、深度优先搜索
- 难度:简单
描述:给定一个二叉树的根节点 root
和一个值 targetSum
。
要求:判断该树中是否存在从根节点到叶子节点的路径,使得这条路径上所有节点值相加等于 targetSum
。如果存在,返回 True
;否则,返回 False
。
说明:
- 树中节点的数目在范围
$[0, 5000]$ 内。 -
$-1000 \le Node.val \le 1000$ 。 -
$-1000 \le targetSum \le 1000$ 。
示例:
- 示例 1:
输入: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 的根节点到叶子节点的路径。
- 定义一个递归函数,递归函数传入当前根节点
root
,目标节点和targetSum
,以及新增变量currSum
(表示为从根节点到当前节点的路径上所有节点值之和)。 - 递归遍历左右子树,同时更新维护
currSum
值。 - 如果当前节点为叶子节点时,判断
currSum
是否与targetSum
相等。- 如果
currSum
与targetSum
相等,则返回True
。 - 如果
currSum
不与targetSum
相等,则返回False
。
- 如果
- 如果当前节点不为叶子节点,则继续递归遍历左右子树。
class Solution:
def hasPathSum(self, root: TreeNode, targetSum: int) -> bool:
return self.sum(root, targetSum, 0)
def sum(self, root: TreeNode, targetSum: int, curSum:int) -> bool:
if root == None:
return False
curSum += root.val
if root.left == None and root.right == None:
return curSum == targetSum
else:
return self.sum(root.left, targetSum, curSum) or self.sum(root.right, targetSum, curSum)
-
时间复杂度:$O(n)$,其中
$n$ 是二叉树的节点数目。 -
空间复杂度:$O(n)$。递归函数需要用到栈空间,栈空间取决于递归深度,最坏情况下递归深度为
$n$ ,所以空间复杂度为$O(n)$ 。