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

全部评论

相关推荐

RickieOne:还有一个面试,上来就笔试算法 1️⃣ 字符串分割不能用 split ,ab&&c,根据&&放到数组上 2️⃣a 到 z 的全部组合情况,包括 a...z 3️⃣多线程,同时打印 1-200 4️⃣sql 代码 考分组 聚合 平均结合 小厂也这样吗,然后就八股 再拷打项目
点赞 评论 收藏
分享
评论
3
收藏
分享

创作者周榜

更多
牛客网
牛客企业服务