leet-code/src/main/java/leetcode/editor/cn/PathSum.java
2021-10-19 15:12:15 +08:00

94 lines
2.2 KiB
Java
Raw Blame History

This file contains ambiguous Unicode characters

This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

//给你二叉树的根节点 root 和一个表示目标和的整数 targetSum ,判断该树中是否存在 根节点到叶子节点 的路径,这条路径上所有节点值相加等于目标和
// targetSum 。
//
// 叶子节点 是指没有子节点的节点。
//
//
//
// 示例 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
//
//
// 示例 3
//
//
//输入root = [1,2], targetSum = 0
//输出false
//
//
//
//
// 提示:
//
//
// 树中节点的数目在范围 [0, 5000] 内
// -1000 <= Node.val <= 1000
// -1000 <= targetSum <= 1000
//
// Related Topics 树 深度优先搜索 二叉树 👍 702 👎 0
package leetcode.editor.cn;
import com.code.leet.entiy.TreeNode;
//112:路径总和
class PathSum {
public static void main(String[] args) {
//测试代码
Solution solution = new PathSum().new Solution();
}
//力扣代码
//leetcode submit region begin(Prohibit modification and deletion)
/**
* Definition for a binary tree node.
* public class TreeNode {
* int val;
* TreeNode left;
* TreeNode right;
* TreeNode() {}
* TreeNode(int val) { this.val = val; }
* TreeNode(int val, TreeNode left, TreeNode right) {
* this.val = val;
* this.left = left;
* this.right = right;
* }
* }
*/
class Solution {
public boolean hasPathSum(TreeNode root, int targetSum) {
if (root == null) {
return false;
}
return dfs(root, 0, targetSum);
}
private boolean dfs(TreeNode root, int sum, int targetSum) {
if (root.left == null && root.right == null) {
return root.val + sum == targetSum;
}
if (root.left != null) {
if (dfs(root.left, sum + root.val, targetSum)) {
return true;
}
}
if (root.right != null) {
return dfs(root.right, sum + root.val, targetSum);
}
return false;
}
}
//leetcode submit region end(Prohibit modification and deletion)
}