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

全部评论

相关推荐

好像有点准
我推的MK:感觉这个表格呢好像有用又好像没用,真有offer了不管加班多么严重也得受着,没offer管他加班什么样也只能看看,反正轮不到我选
点赞 评论 收藏
分享
咩咩子_:项目和图形引擎岗没啥关系,最好还是项目和岗位有相关度好点,不然真有面也不一定会问很多
点赞 评论 收藏
分享
03-16 13:56
湖南大学 C++
牛客872108596号:到现在没消息是挂了吗查看图片
点赞 评论 收藏
分享
评论
3
收藏
分享

创作者周榜

更多
牛客网
牛客企业服务