算法通关村第五关-二叉树遍历(深度优先)之经典问题: 递归/迭代实现二叉树前、中、后序遍历

基础知识(青铜挑战)

  • 理解递归思想:调用自己、压栈、明确终止条件

实战训练(白银挑战)

递归实现二叉树的前、中、后序遍历
  • 我的建议是直接把代码背下来

  • 你当然可以尝试去理解,也不是很难想明白,但是不要钻牛角尖了,递归这玩意儿,很不友好

java 复制代码
 /**
     * 前序遍历,将结果返回到list中
     *
     * @param root
     * @param res
     */
​
    public static void preOrder(TreeNode root, List<Integer> res) {
        if (root == null) {
            return;
        }
        res.add(root.val);
        preOrder(root.left, res);
        preOrder(root.right, res);
    }
​
   
复制代码
 
java 复制代码
 /**
     * 中序遍历,将结果返回到list中
     *
     * @param root
     * @param res
     */
  public static void inOrder(TreeNode root, List<Integer> res) {
        if (root == null) {
            return;
        }
        inOrder(root.left, res);
        res.add(root.val);
        inOrder(root.right, res);
    }
​
java 复制代码
  /**
     * 后序遍历,将结果返回到list中
     *
     * @param root
     * @param res
     */
    public static void postOrder(TreeNode root, List<Integer> res) {
        if (root == null) {
            return;
        }
        postOrder(root.left, res);
        postOrder(root.right, res);
        res.add(root.val);
    }
迭代实现二叉树的前、中、后序遍历
前序遍历
java 复制代码
   public static List<Integer> preOrderTraversal(TreeNode root) {
        List<Integer> res = new ArrayList<Integer>();
        if (root == null) {
            return res;
        }
​
        Deque<TreeNode> stack = new LinkedList<TreeNode>();
        TreeNode node = root;
        while (!stack.isEmpty() || node != null) {
            while (node != null) {
                res.add(node.val);
                stack.push(node);
                node = node.left;
            }
​
            node = stack.pop();
            node = node.right;
        }
        return res;
    } 
复制代码
  
中序遍历(2023/09/12午)
java 复制代码
public static List<Integer> inorderTraversal(TreeNode root) {
        List<Integer> res = new ArrayList<Integer>();
        Deque<TreeNode> stack = new LinkedList<TreeNode>();
​
        while (root != null || !stack.isEmpty()) {
            while (root != null) {
                stack.push(root);
                root = root.left;
            }
​
            root = stack.pop();
            res.add(root.val);
            root = root.right;
        }
        return res;
    }
  • 前序遍历和中序遍历的代码不复杂,还是注意:挺不好理解的,不要钻牛角尖,那么我们接下来看下后序遍历

后序遍历
  • 这个相较于前两个更难实现,但可以这样想:

    • 前序遍历的顺序是:中、左、右,我们简单该两个参数,实现遍历顺序为中、右、左

    • 再将遍历结果reserve反转,不就得到左、右、中的遍历顺序了吗?

java 复制代码
  public static List<Integer> postOrderTraversal(TreeNode root) {
        List<Integer> res = new ArrayList<>();
        if (root == null) return res;
        Stack<TreeNode> stack = new Stack<>();
        TreeNode node = root;
​
        while (!stack.isEmpty() || node != null) {
            while (node != null) {
                res.add(node.val);
                stack.push(node);
                node = node.right;
            }
            node = stack.pop();
            node = node.left;
        }
        Collections.reverse(res);
        return res;
    }

通关(过关挑战)

理解中序遍历的递归过程,挺难的,努努力吧(2023/09/12午)
相关推荐
戊辰happy1 小时前
arcface
算法
陌上花开࿈2 小时前
调用第三方接口
java
浊酒南街2 小时前
决策树python实现代码1
python·算法·决策树
Aileen_0v02 小时前
【玩转OCR | 腾讯云智能结构化OCR在图像增强与发票识别中的应用实践】
android·java·人工智能·云计算·ocr·腾讯云·玩转腾讯云ocr
冠位观测者3 小时前
【Leetcode 热题 100】208. 实现 Trie (前缀树)
数据结构·算法·leetcode
桂月二二4 小时前
Java与容器化:如何使用Docker和Kubernetes优化Java应用的部署
java·docker·kubernetes
liuxin334455664 小时前
学籍管理系统:实现教育管理现代化
java·开发语言·前端·数据库·安全
小马爱打代码4 小时前
设计模式详解(建造者模式)
java·设计模式·建造者模式
小王爱吃月亮糖4 小时前
C++的23种设计模式
开发语言·c++·qt·算法·设计模式·ecmascript
栗子~~5 小时前
idea 8年使用整理
java·ide·intellij-idea