
时间复杂度:O(n)
解题思路
借助于后序遍历的递归思想。针对于一开始的root结点为空的情况,先判断当前遍历的结点是否为空,如果为空就返回false。然后判断当前节点是否为叶子结点,如果是再判断节点值是否和targetsum值相等,如果相等返回true,否则返回false。最后分别遍历root的左右结点,并使当前的targetSum减去root的val值,如果有一个孩子返回true那么就返回true,说明有一条路径满足要求。
AC代码
/**
* Definition for a binary tree node.
* type TreeNode struct {
* Val int
* Left *TreeNode
* Right *TreeNode
* }
*/
func hasPathSum(root *TreeNode, targetSum int) bool {
if root==nil{
return false
}
if root.Left==nil&&root.Right==nil{
return targetSum==root.Val
}
return hasPathSum(root.Left,targetSum-root.Val)||hasPathSum(root.Right,targetSum-root.Val)
}
感悟
由于是先做的路径总和II题,受那道题的影响自己先实现了一个递归函数,看了题解后发现完全可以通过题目自带的函数递归解决,只需要不断地让targetSum减去root的val值即可。

文章介绍了如何利用后序遍历和递归方法解决二叉树中是否存在一条路径,其节点值之和等于给定的目标值。首先检查根节点是否为空,然后判断是否为叶子节点并比较目标值。接着,通过递归遍历左右子树,不断更新目标值。这是一个典型的二叉树问题,强调了递归解题的思路。
1340

被折叠的 条评论
为什么被折叠?



