题目
给定一个二叉树和一个值sum,判断是否有从根节点到叶子节点的节点值之和等于sum 的路径,
例如:
给出如下的二叉树, sum=22,

返回true,因为存在一条路径5→4→11→2的节点值之和为 22
代码
/*
* public class TreeNode {
* int val = 0;
* TreeNode left = null;
* TreeNode right = null;
* }
*/
public class Solution {
/**
*
* @param root TreeNode类
* @param sum int整型
* @return bool布尔型
*/
public boolean hasPathSum (TreeNode root, int sum) { //递归算法,先序遍历
if(root==null)
return false;
sum-=root.val;
if(sum==0&&root.left==null&&root.right==null)
return true;
return hasPathSum(root.left,sum)||hasPathSum(root.right,sum);
}
}
738

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



