129. 求根到叶子节点数字之和(树)

一时失言乱红尘 2022-11-21 04:10 248阅读 0赞

1.题目描述

给定一个二叉树,它的每个结点都存放一个 0-9 的数字,每条从根到叶子节点的路径都代表一个数字。

例如,从根到叶子节点路径 1->2->3 代表数字 123。

计算从根到叶子节点生成的所有数字之和。

说明: 叶子节点是指没有子节点的节点。

示例 1:

输入: [1,2,3]
1
/ \
2 3
输出: 25
解释:
从根到叶子节点路径 1->2 代表数字 12.
从根到叶子节点路径 1->3 代表数字 13.
因此,数字总和 = 12 + 13 = 25.

2.java代码

  1. package com.tree.medium.LeetCode129;
  2. import java.util.LinkedList;
  3. import java.util.Queue;
  4. /**
  5. * @author GMT
  6. * @version 1.0
  7. * @create 2020-10-2922:00
  8. */
  9. // 结构体构造tree
  10. class TreeNode {
  11. int val;
  12. TreeNode left;
  13. TreeNode right;
  14. TreeNode(int x) {
  15. this.val = x;
  16. }
  17. //添加结点
  18. public TreeNode addNode(TreeNode parentNode, int data, boolean isLeft) {
  19. //父节点为空,无法添加子节点
  20. if (parentNode == null)
  21. throw new RuntimeException("父节点为空,无法添加子节点");
  22. if (isLeft && parentNode.left != null)
  23. throw new RuntimeException("左子节点已经存在,添加失败");
  24. if (!isLeft && parentNode.right != null)
  25. throw new RuntimeException("右子节点已经存在,添加失败");
  26. TreeNode newNode = new TreeNode(data);
  27. if (isLeft) {
  28. parentNode.left = newNode;
  29. } else {
  30. parentNode.right = newNode;
  31. }
  32. return newNode;
  33. }
  34. }
  35. public class Solution {
  36. /**
  37. * 方法一:
  38. * 使用深度优先遍历方法
  39. * 执行用时:0 ms, 在所有 Java 提交中击败了100.00%的用户
  40. * 内存消耗:36.4 MB, 在所有 Java 提交中击败了76.76%的用户
  41. * 时间复杂度:O(n),其中 n 是二叉树的节点个数。对每个节点访问一次。
  42. * 空间复杂度:O(n),其中 n 是二叉树的节点个数。
  43. * 空间复杂度主要取决于递归调用的栈空间,递归栈的深度等于二叉树的高度,最坏情况下,二叉树的高度等于节点个数,
  44. *
  45. * 首先定义一个sum为0,遍历从根结点开始计算dfs(root,sum)
  46. * 当根节点为空返回,否则,将之前和*10加上现在节点的值,赋值给sum变量
  47. * 当左右为空时候,返回sum,否则返回dfs(left,sum)+dfs(right,sum)
  48. */
  49. public int sumNumbers1(TreeNode root) {
  50. return dfs(root, 0);
  51. }
  52. private int dfs(TreeNode node, int preSum) {
  53. if (node == null) {
  54. return 0;
  55. }
  56. int sum = preSum * 10 + node.val;
  57. if (node.left == null && node.right == null) {
  58. return sum;
  59. } else {
  60. return dfs(node.left, sum) + dfs(node.right, sum);
  61. }
  62. }
  63. /**
  64. * 方法二:
  65. * 使用广度优先遍历
  66. * 执行用时:1 ms, 在所有 Java 提交中击败了31.18%的用户
  67. * 内存消耗:36.5 MB, 在所有 Java 提交中击败了70.85%的用户
  68. *
  69. * 使用java中队列 linkedlist的父类是queue队列
  70. * Queue<TreeNode> nodeQueue = new LinkedList<TreeNode>();
  71. * 用到了里面的offer和poll方法
  72. */
  73. public int sumNumbers2(TreeNode root) {
  74. if (root == null) return 0;
  75. int sum = 0;
  76. Queue<TreeNode> nodeQueue = new LinkedList<TreeNode>();
  77. Queue<Integer> numQueue = new LinkedList<Integer>();
  78. nodeQueue.offer(root);
  79. numQueue.offer(root.val);
  80. while (!nodeQueue.isEmpty()) {
  81. TreeNode node = nodeQueue.poll();
  82. int num = numQueue.poll();
  83. TreeNode left = node.left;
  84. TreeNode right = node.right;
  85. if (left == null && right == null) sum += num;
  86. else {
  87. if (left != null) {
  88. nodeQueue.offer(left);
  89. numQueue.offer(num * 10 + left.val);
  90. }
  91. if (right != null) {
  92. nodeQueue.offer(right);
  93. numQueue.offer(num * 10 + right.val);
  94. }
  95. }
  96. }
  97. return sum;
  98. }
  99. public static void main(String[] args) {
  100. TreeNode root = new TreeNode(1);
  101. root.addNode(root, 1, true);//11
  102. root.addNode(root, 2, false);//12
  103. Solution solution = new Solution();
  104. int ans1 = solution.sumNumbers1(root);
  105. System.out.println(ans1);
  106. int ans2 = solution.sumNumbers2(root);
  107. System.out.println(ans2);
  108. }
  109. }

watermark_type_ZmFuZ3poZW5naGVpdGk_shadow_10_text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L1N1eWViaXViaXU_size_16_color_FFFFFF_t_70

发表评论

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

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

相关阅读