给出一棵二叉树,返回其节点值的后序遍历。
样例
给出一棵二叉树 {1,#,2,3}
,
1 \ 2 / 3
返回 [3,2,1]
挑战
你能使用非递归实现么?
/**
* Definition of TreeNode:
* public class TreeNode {
* public int val;
* public TreeNode left, right;
* public TreeNode(int val) {
* this.val = val;
* this.left = this.right = null;
* }
* }
*/
public class Solution {
public ArrayList<Integer> postorderTraversal(TreeNode root) {
TreeNode temp=root;
Stack<TreeNode> stack=new Stack<TreeNode>();
ArrayList<Integer> list=new ArrayList<Integer>();
while(root!=null)
{
for(;root.left!=null;root=root.left)
stack.push(root);
while(root!=null&&(root.right==null)||root.right==temp)
{
list.add(root.val);
temp=root;
if(stack.isEmpty())
return list;
root=stack.pop();
}
stack.push(root);
root=root.right;
}
return list;
}
}