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

基础知识(青铜挑战)

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

实战训练(白银挑战)

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

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

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午)
相关推荐
程序员-King.3 分钟前
双指针/滑动窗口—算法总结与教学指南
经验分享·算法·双指针
杀死那个蝈坦7 分钟前
Docker
java·docker·eclipse·tomcat·hibernate
a3158238068 分钟前
Android13隐藏某个App需要关注的源码文件
android·java·framework·launcher3·隐藏app
悟空码字15 分钟前
SpringBoot实现消息推送:让服务器学会“主动搭讪”
java·spring boot·后端
小武~17 分钟前
Leetcode 每日一题C 语言版 -- 274 H-index
c语言·算法·leetcode
0 0 021 分钟前
CCF-CSP 36-3 缓存模拟(cache)【C++】
开发语言·c++·算法
蒟蒻小袁21 分钟前
Hot100--找到字符串中所有字母异位词
java·算法·leetcode·面试
kingmax5421200827 分钟前
高中数学教师资格面试试讲稿:《直线的位置关系(例2)》
线性代数·算法·面试·矩阵·教师资格
吃着火锅x唱着歌28 分钟前
LeetCode 2909.元素和最小的山形三元组II
数据结构·算法·leetcode