129. Sum Root to Leaf Numbers (example)
https://leetcode.com/problems/sum-root-to-leaf-numbers/
ๅ จๅ่ฎๆธ
```java
class Solution {
int sum = 0;
public int sumNumbers(TreeNode root) {
dfs(root, 0);
return sum;
}
private void dfs(TreeNode node, int preSum) {
if (node == null) {
return;
}
preSum = preSum*10 + node.val;
if (node.left == null && node.right == null) {
sum += preSum;
}
dfs(node.left, preSum);
dfs(node.right, preSum);
}
}
```
trick point:
int currentSum = sum*10 + root.val;
class Solution {
public int sumNumbers(TreeNode root) {
return cal(root, 0);
}
private int cal(TreeNode root, int sum) {
if (root == null) {
return 0;
}
int currentSum = sum*10 + root.val;
if (root.left == null && root.right == null) {
return currentSum;
}
return cal(root.left, currentSum) + cal(root.right, currentSum);
}
}
ไธ้ขๆฏๅ ๅจ dfs ๅ งๅๅณ...่ ปๅฒๅฎณ็, ่งฃๆณไธๆฏๆฏ่ผ็ฐกๅฎ๏ผ
ไธ้ขๆฏ้็นๅฅ็ตฆไบ่ฎๆธ result, umm...ไนไธ็จๅคๆท left == null, ๅ้ขๆๆไฝ
```java
class Solution {
public int sumNumbers(TreeNode root) {
return dfs(root, 0, 0);
}
private int dfs(TreeNode node, int preSum, int result) {
if (node == null) {
return result; // ๅฆๆ็จ result = dfs(left..., ่ฆ return result, ไธ็ถๆ่ขซ่้ๅป, ๆไปฅ้ๆฏ็ธๅ ๅง๏ผ
}
int currentSum = preSum*10 + node.val;
if (node.left == null && node.right == null) {
result += currentSum;
return result;
}
if (node.left != null) {
result = dfs(node.left, currentSum, result);
}
if (node.right != null) {
result = dfs(node.right, currentSum, result);
}
return result;
}
}
```
all follow this:
T: O(n)
S: O(n)
/**
* 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 int sumNumbers(TreeNode root) {
return dfs(root, 0);
}
private int dfs(TreeNode node, int pre) {
if (node == null) {
return 0;
}
int val = pre*10 + node.val;
if (node.left == null && node.right == null) {
return val;
}
return dfs(node.left, val) + dfs(node.right, val);
}
}
/***
1
pre*10 + cur.val
*/
Last updated