Skip to content

Commit fe17840

Browse files
author
bcx20
committed
Week 2 homework submit
1 parent cc7f175 commit fe17840

4 files changed

Lines changed: 98 additions & 0 deletions
Lines changed: 26 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,26 @@
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 List<Integer> inorderTraversal(TreeNode root) {
12+
List<Integer> res = new ArrayList<Integer>();
13+
Stack<TreeNode> stk = new Stack<TreeNode>();
14+
TreeNode currentNode = root;
15+
while(currentNode != null || !stk.empty()) {
16+
while(currentNode != null) {
17+
stk.push(currentNode);
18+
currentNode = currentNode.left;
19+
}
20+
currentNode = stk.pop();
21+
res.add(currentNode.val);
22+
currentNode = currentNode.right;
23+
}
24+
return res;
25+
}
26+
}
Lines changed: 23 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,23 @@
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 List<Integer> inorderTraversal(TreeNode root) {
12+
List<Integer> res = new ArrayList<Integer>();
13+
this.traverse(res, root);
14+
return res;
15+
}
16+
17+
public void traverse(List<Integer> res, TreeNode root) {
18+
if (root == null) return;
19+
this.traverse(res, root.left);
20+
res.add(root.val);
21+
traverse(res, root.right);
22+
}
23+
}
Lines changed: 26 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,26 @@
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 List<Integer> preorderTraversal(TreeNode root) {
12+
List<Integer> res = new ArrayList<Integer>();
13+
Stack<TreeNode> stk = new Stack<TreeNode>();
14+
TreeNode currentNode = root;
15+
while(currentNode != null || !stk.empty()) {
16+
while(currentNode != null) {
17+
res.add(currentNode.val);
18+
stk.push(currentNode);
19+
currentNode = currentNode.left;
20+
}
21+
currentNode = stk.pop();
22+
currentNode = currentNode.right;
23+
}
24+
return res;
25+
}
26+
}
Lines changed: 23 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,23 @@
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 List<Integer> preorderTraversal(TreeNode root) {
12+
List<Integer> res = new ArrayList<Integer>();
13+
this.traverse(res, root);
14+
return res;
15+
}
16+
17+
public void traverse(List<Integer> res, TreeNode root) {
18+
if(root == null) return;
19+
res.add(root.val);
20+
this.traverse(res, root.left);
21+
this.traverse(res, root.right);
22+
}
23+
}

0 commit comments

Comments
 (0)