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;  
    }  
}

执行结果:

三、小结

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

结语

你做得已经很好了

别对自己太苛刻

!!!

相关推荐
Omigeq4 小时前
1.4 - 曲线生成轨迹优化算法(以BSpline和ReedsShepp为例) - Python运动规划库教程(Python Motion Planning)
开发语言·人工智能·python·算法·机器人
成为大佬先秃头4 小时前
前后分离项目:整合JWT+Shiro
java·springboot·shiro·jwt
网络工程小王4 小时前
【大模型(LLM)的业务开发】学习笔记
人工智能·算法·机器学习
y = xⁿ4 小时前
【Leet Code 】滑动窗口
java·算法·leetcode
WBluuue4 小时前
数据结构与算法:二项式定理和二项式反演
c++·算法
nianniannnn4 小时前
力扣104.二叉树的最大深度 110. 平衡二叉树
算法·leetcode·深度优先
day day day ...4 小时前
MyBatis条件误写引发的查询条件污染分析与防范
java·服务器·tomcat
_深海凉_4 小时前
LeetCode热题100-只出现一次的数字
算法·leetcode·职场和发展
hrhcode4 小时前
【java工程师快速上手go】一.Go语言基础
java·开发语言·golang
nianniannnn4 小时前
力扣206.反转链表 92.反转链表II
算法·leetcode·链表