LeetCode-94-二叉树的中序遍历

题目:

给定一个二叉树的根节点 root ,返回 它的 中序 遍历 。

解法一: 递归写法

思路: 先处理左子树 inOrder(root.left),在打印root的值,之后处理右子树。

复制代码
public static void inOrder(TreeNode root){
        if (root == null){
            return;
        }
        inOrder(root.left);
        System.out.print(root.val + " ");
        inOrder(root.right);
    }

解法二: 用栈改造中序递归

注意:二叉树的先,中,后序遍历都可以用栈来改造成非递归写法。

用栈改造中序递归的基本思路就是,一路向下查找节点的左孩子,如果有左孩子,入栈,这样的话,可以保证最后一个左孩子先出栈,如果某一节点左孩子为空,pop出上一个左孩子并处理,之后对右孩子也执行相同的操作。

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

如果想看二叉树的全部递归与非递归代码,请点击:二叉树的递归与非递归遍历方式

相关推荐
Oliver_LaVine16 分钟前
java项目启动报错:CreateProcess error=206, 文件名或扩展名太长
java·linux·jenkins
6Hzlia20 分钟前
【Hot 100 刷题计划】 LeetCode 300. 最长递增子序列 | C++ 动态规划 & 贪心二分
c++·leetcode·动态规划
6Hzlia25 分钟前
【Hot 100 刷题计划】 LeetCode 72. 编辑距离 | C++ 经典 DP 增删改状态转移
c++·算法·leetcode
穿条秋裤到处跑25 分钟前
每日一道leetcode(2026.04.16):距离最小相等元素查询
算法·leetcode·职场和发展
码农周44 分钟前
告别大体积PDF!基于PDFBox的Java压缩工具
java·spring boot
devilnumber1 小时前
java中Redisson ,jedis,Lettuce和Spring Data Redis的四种深度对比和优缺点详解
java·redis·spring
摇滚侠1 小时前
Java 进阶教程,全面剖析 Java 多线程编程
java·开发语言
yaaakaaang1 小时前
十四、命令模式
java·命令模式
小锋java12341 小时前
【技术专题】Matplotlib3 Python 数据可视化 - Matplotlib3 绘制饼状图(Pie)
java
wuminyu1 小时前
专家视角看JVM_StartThread
java·linux·c语言·jvm·c++