题目:
roott给你二叉树的根节点 整数targetSumm和一个表示目标和的 。判断树是否存在 从根节点到叶节点 这条路径上所有节点值的相加等于目标和targetSumm 。如果存在,返回 true ;否则,返回 false 。
叶子节点 是指没有子节点的节点。
示例 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 根节点到叶节点的路径。
示例 3:
输入:root = [], targetSum = 0
输出:false
说明:因为树是空的,所以没有从根节点到叶节点的路径。
代码实现:
class Solution { public boolean hasPathSum(TreeNode root, int sum) { if (root == null) { return false; } Queue<TreeNode> queNode = new LinkedList<TreeNode>(); Queue<Integer> queVal = new LinkedList<Integer>(); queNode.offer(root); queVal.offer(root.val); while (!queNode.isEmpty()) { TreeNode now = queNode.poll(); int temp = queVal.poll(); if (now.left == null && now.right == null) { if (temp == sum) { return true; } continue; } if (now.left != null) { queNode.offer(now.left); queVal.offer(now.left.val + temp); } if (now.right != null) { queNode.offer(now.right); queVal.offer(now.right.val + temp); } } return false; }}