求给定的二叉树的后序遍历。
例如:
给定的二叉树为{1,#,2,3},
用非递归的方法实现二叉树的后续遍历。
之所以能用递归是因为具有栈的属性,因此在非递归的做法中往往要活用栈和队列这个数据结构。

优秀了,其实就是这么简单。
用一个栈保存待加入result的节点,用另外一个栈保存当前节点访问的状态值,根据不同的状态值进行不同的逻辑处理,就是这么优秀啊。

/**
 * Definition for binary tree
 * public class TreeNode {
 *     int val;
 *     TreeNode left;
 *     TreeNode right;
 *     TreeNode(int x) { val = x; }
 * }
 */
import java.util.ArrayList;
import java.util.Stack;

public class Solution {
    public ArrayList<Integer> postorderTraversal(TreeNode root) {
        Stack<TreeNode> stackNode = new Stack<TreeNode>();
        Stack<Integer> stackFlag = new Stack<Integer>();
        ArrayList<Integer> result = new ArrayList<Integer>();
        if(root == null)return