LeetCode 129. 求根到叶子节点数字之和 JAVA

待我称王封你为后i 2022-11-21 01:09 219阅读 0赞

给定一个二叉树,它的每个结点都存放一个 0-9 的数字,每条从根到叶子节点的路径都代表一个数字。
例如,从根到叶子节点路径 1->2->3 代表数字 123。
计算从根到叶子节点生成的所有数字之和。
说明: 叶子节点是指没有子节点的节点。

  1. 示例 1:
  2. 输入: [1,2,3]
  3. 1
  4. / \
  5. 2 3
  6. 输出: 25
  7. 解释:
  8. 从根到叶子节点路径 1->2 代表数字 12.
  9. 从根到叶子节点路径 1->3 代表数字 13.
  10. 因此,数字总和 = 12 + 13 = 25.
  11. 示例 2:
  12. 输入: [4,9,0,5,1]
  13. 4
  14. / \
  15. 9 0
  16. / \
  17. 5 1
  18. 输出: 1026
  19. 解释:
  20. 从根到叶子节点路径 4->9->5 代表数字 495.
  21. 从根到叶子节点路径 4->9->1 代表数字 491.
  22. 从根到叶子节点路径 4->0 代表数字 40.
  23. 因此,数字总和 = 495 + 491 + 40 = 1026.
  24. 来源:力扣(LeetCode
  25. 链接:https://leetcode-cn.com/problems/sum-root-to-leaf-numbers
  26. 著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。

题解:
对于每一个结点而言,只有四种情况,分别是有左子树和右子树,只有左子树,只有右子树,或者为叶子结点,本题采用了递归解法,只需要考虑到这四种情况的各自返回值就可以了
1、如果有左子树和右子树,那么到达该节点时的数字之和应该为左子树和右子树的的数字之和的和
2、如果只有左子树,那么,到达该节点时的数字之和应该为左子树的数字之和而已
3、如果只有右子树,同理可以得到,到达该节点时的数字之和应该为右子树的数字之和而已
4、如果该节点为叶子结点,那么,就应该返回自身结点数字之和

  1. /**
  2. * Definition for a binary tree node.
  3. * public class TreeNode {
  4. * int val;
  5. * TreeNode left;
  6. * TreeNode right;
  7. * TreeNode(int x) { val = x; }
  8. * }
  9. */
  10. class Solution {
  11. public int sumNumbers(TreeNode root) {
  12. return sumNumbers(root,0);
  13. }
  14. public int sumNumbers(TreeNode root,int pre){
  15. if(root==null) return pre;
  16. pre=pre*10+root.val;
  17. if(root.left!=null&&root.right!=null)
  18. return sumNumbers(root.left,pre)+sumNumbers(root.right,pre);
  19. else if(root.left==null&&root.right==null)
  20. return pre;
  21. else if(root.left==null&&root.right!=null)
  22. return sumNumbers(root.right,pre);
  23. else
  24. return sumNumbers(root.left,pre);
  25. }
  26. }

发表评论

表情:
评论列表 (有 0 条评论,219人围观)

还没有评论,来说两句吧...

相关阅读