Leetcode JAVA刷刷站(94)二叉树的中序遍历

一、题目概述

二、思路方向

在Java中,中序遍历二叉树通常使用递归或迭代(使用栈)的方法来实现。这里我将提供两种方法的示例代码。

方法一:递归

递归方法相对直观,中序遍历的顺序是:先遍历左子树,然后访问根节点,最后遍历右子树。

java 复制代码
class TreeNode {  
    int val;  
    TreeNode left;  
    TreeNode right;  
    TreeNode(int x) { val = x; }  
}  
  
public class Solution {  
    public List<Integer> inorderTraversal(TreeNode root) {  
        List<Integer> result = new ArrayList<>();  
        inorderHelper(root, result);  
        return result;  
    }  
  
    private void inorderHelper(TreeNode node, List<Integer> result) {  
        if (node == null) {  
            return;  
        }  
        inorderHelper(node.left, result);  
        result.add(node.val);  
        inorderHelper(node.right, result);  
    }  
}

方法二:迭代(使用栈)

迭代方法需要手动维护一个栈来模拟递归过程。

java 复制代码
import java.util.*;  
  
class TreeNode {  
    int val;  
    TreeNode left;  
    TreeNode right;  
    TreeNode(int x) { val = x; }  
}  
  
public class Solution {  
    public List<Integer> inorderTraversal(TreeNode root) {  
        List<Integer> result = new ArrayList<>();  
        Stack<TreeNode> stack = new Stack<>();  
        TreeNode curr = root;  
  
        while (curr != null || !stack.isEmpty()) {  
            // 遍历到最左节点  
            while (curr != null) {  
                stack.push(curr);  
                curr = curr.left;  
            }  
            // 弹出栈顶元素并访问  
            curr = stack.pop();  
            result.add(curr.val);  
            // 转向右子树  
            curr = curr.right;  
        }  
  
        return result;  
    }  
}

执行结果:

三、小结

两种方法各有优缺点。递归方法代码简洁,但在树非常深时可能会遇到栈溢出的问题。迭代方法虽然代码稍长,但避免了递归可能带来的栈溢出问题,且在某些情况下可能更高效(如树非常不平衡时)。你可以根据具体的应用场景和需求选择适合的方法。

结语

你做得已经很好了

别对自己太苛刻

!!!

相关推荐
网安INF23 分钟前
CVE-2020-17519源码分析与漏洞复现(Flink 任意文件读取)
java·web安全·网络安全·flink·漏洞
一叶知秋哈23 分钟前
Java应用Flink CDC监听MySQL数据变动内容输出到控制台
java·mysql·flink
jackson凌28 分钟前
【Java学习笔记】SringBuffer类(重点)
java·笔记·学习
chao_78930 分钟前
链表题解——两两交换链表中的节点【LeetCode】
数据结构·python·leetcode·链表
sclibingqing34 分钟前
SpringBoot项目接口集中测试方法及实现
java·spring boot·后端
程序员JerrySUN38 分钟前
全面理解 Linux 内核性能问题:分类、实战与调优策略
java·linux·运维·服务器·单片机
糯米导航42 分钟前
Java毕业设计:办公自动化系统的设计与实现
java·开发语言·课程设计
糯米导航1 小时前
Java毕业设计:WML信息查询与后端信息发布系统开发
java·开发语言·课程设计
米粉03051 小时前
深入剖析Nginx:从入门到高并发架构实战
java·运维·nginx·架构
简诚1 小时前
HttpURLConnection实现
java