Skip to content

Commit cd66f41

Browse files
authored
Update Binary Search Tree to Greater Sum Tree.java
1 parent aef8f1a commit cd66f41

File tree

1 file changed

+18
-20
lines changed

1 file changed

+18
-20
lines changed

Medium/Binary Search Tree to Greater Sum Tree.java

Lines changed: 18 additions & 20 deletions
Original file line numberDiff line numberDiff line change
@@ -4,32 +4,30 @@
44
* int val;
55
* TreeNode left;
66
* TreeNode right;
7-
* TreeNode(int x) { val = x; }
7+
* TreeNode() {}
8+
* TreeNode(int val) { this.val = val; }
9+
* TreeNode(int val, TreeNode left, TreeNode right) {
10+
* this.val = val;
11+
* this.left = left;
12+
* this.right = right;
13+
* }
814
* }
915
*/
1016
class Solution {
1117
public TreeNode bstToGst(TreeNode root) {
12-
if (root == null) {
13-
return null;
14-
}
15-
TreeNode curr = root;
16-
Stack<TreeNode> stack = new Stack<>();
1718
int sum = 0;
18-
pushRight(stack, curr);
19-
while (!stack.isEmpty()) {
20-
TreeNode removed = stack.pop();
21-
sum += removed.val;
22-
removed.val = sum;
23-
TreeNode leftNode = removed.left;
24-
pushRight(stack, leftNode);
19+
TreeNode node = root;
20+
Stack<TreeNode> stack = new Stack<>();
21+
while (!stack.isEmpty() || node != null) {
22+
while (node != null) {
23+
stack.add(node);
24+
node = node.right;
25+
}
26+
node = stack.pop();
27+
sum += node.val;
28+
node.val = sum;
29+
node = node.left;
2530
}
2631
return root;
2732
}
28-
29-
private void pushRight(Stack<TreeNode> stack, TreeNode curr) {
30-
while (curr != null) {
31-
stack.push(curr);
32-
curr = curr.right;
33-
}
34-
}
3533
}

0 commit comments

Comments
 (0)