leetcode-树练习-binary-tree-postorder-traversal
binary-tree-postorder-traversal
https://www.nowcoder.com/practice/32af374b322342b68460e6fd2641dd1b?tpId=46&tqId=29035&tPage=1&rp=1&ru=/ta/leetcode&qru=/ta/leetcode/question-ranking
求给定的二叉树的后序遍历。
例如:
给定的二叉树为{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>();
剩余60%内容,订阅专栏后可继续查看/也可单篇购买
小白刷Leetcode 文章被收录于专栏
那些必刷的leetcode