题解 | #二叉树中和为某一值的路径(一)#
二叉树中和为某一值的路径(一)
https://www.nowcoder.com/practice/508378c0823c423baa723ce448cbfd0c
import java.util.*; /* * 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) { // write code here if(root == null){ return false; } if(root.left == null && root.right == null){ return root.val == sum; } return hasPathSum(root.left , sum - root.val) || hasPathSum(root.right , sum - root.val); } }
思路:用递归,出口,root null,return false,左右子树为 null ,return root.val sum。然后一层一层递归,用sum-root.val 。左子树和右子树之间的关系是,|| 这点很关键。