news 2026/6/23 21:40:20

力扣-94.二叉树的中序遍历(Java递归)

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
力扣-94.二叉树的中序遍历(Java递归)

文章目录

94.二叉树的中序遍历(力扣题目)

题目描述

问题理解

题解

时间复杂度分析

图示解析

总结


94.二叉树的中序遍历(力扣题目)

题目描述

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

示例 1:

输入:root = [1,null,2,3]输出:[1,3,2]

示例 2:

输入:root = []输出:[]

示例 3:

输入:root = [1]输出:[1]

提示:

  • 树中节点数目在范围[0, 100]
  • -100 <= Node.val <= 100

问题理解

二叉树的中序遍历是先找当前节点是否有左节点,如果有就先找左节点,如果没有就遍历自己然后再找右节点,循环往复这个操作。这个文字问题我们能翻译成代码。


题解

/** * Definition for a binary tree node. * public class TreeNode { * int val; * TreeNode left; * TreeNode right; * TreeNode() {} * TreeNode(int val) { this.val = val; } * TreeNode(int val, TreeNode left, TreeNode right) { * this.val = val; * this.left = left; * this.right = right; * } * } */ class Solution { List<Integer> result = new ArrayList<>(); public List<Integer> inorderTraversal(TreeNode root) { if(root != null) function(root); return result; } public void function(TreeNode node){ // 查找左节点操作 if(node.left != null) function(node.left); // 对自身进行操作,可以print自身,但是我们根据题目要求添加到一个列表中最后全部打印出来 result.add(node.val); // 查找右节点操作 if(node.right != null) function(node.right); } }

时间复杂度分析

有多少个节点递归函数就要运行多少遍,所以时间复杂度为O(n)


图示解析

本图示解析为二叉树的中序递归遍历。本图示解析中绿色代表带输出节点,红色为已输出节点,白色为未查找节点,图示分析第二行文字描述为伪代码解析(functionx中x代表当前节点的值)。

1.以根节点5开始,查找节点的左子树,找到左节点3,进入左节点3。

function5查找左节点不为空进入function3

2.进入节点3,查找节点3的左节点,找到左节点2,进入左节点2。

function3查找左节点不为空,进入function2

3.进入节点2,查找节点2的左节点,左节点为空,打印自身,然后查找右节点,右节点也为空,返回上一级(因为节点2已经打印完成所以是红色的状态)。

function2查找左节点为空,打印自身,查找右节点为空,function2函数结束返回function3函数。因为function3是运行到一半进入function2函数所以调用function2函数结束之后回到function3。

4.返回节点3,遍历自身,查找右节点,找到右节点4,进入右节点4。function3打印自身,查找右节点不为空,进入function4

5.进入节点4,查找右节点为空,打印自己,查找右节点为空返回上一级,节点3的左节点、自身、右节点已经完成,返回根节点5,打印自己然后查找右节点8,进入又节点8。

function4查找左节点为空,打印自身,查找右节点为空,function4函数结束返回function3函数,function3函数结束返回function5函数,打印自身,查找右节点不为空,进入function8

6.进入节点8,查找左节点不为空,进入左节点7。function8查找左节点不为空,进入function7

7.进入节点7,查找左节点为空,打印自身,查找右节点为空,返回父节点8。

function8进入function7,function7查找左节点为空,打印自身,function7查找右节点为空。function7函数结束返回function8函数。

8.进入节点8,打印自身,查找左节点不为空,进入节点9

function7结束,fuction8左节点查找操作完成,打印自身,查找function8的右节点不为空,进入function9

9.进入节点9,查找左节点为空,打印自身,查找右节点为空,自此二叉树的中序遍历全部完成。

fuction8查找右节点进入function9,function9查找左节点为空,打印自身,function9查找右节点为空。function9函数结束返回function8函数,function8函数查找右节点操作完成,function8函数结束返回function5函数,function5函数查找左节点操作完成,function5函数结束,自此程序运行完毕


总结

递归是“自身调用自身,逐步拆解问题”,本质是把复杂的大问题拆解为结构相同的小问题,直到触达 “终止条件” 后回溯合并结果。递归非常适合二叉树的遍历,已经完成了二叉树的中序遍历(左根右),可以试着自己完成二叉树的前序(根左右)和后序(左右根)遍历。


如果你觉得这篇论文对你有帮助的话,欢迎点赞、收藏并分享给身边在学算法的小伙伴

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/23 17:25:06

综合素质面试hr面

个人对大模型的了解基于深度学习的超大规模参数模型&#xff0c;通常拥有数十亿到数万亿的参数&#xff0c;依赖海量数据和算力训练而成。它们的代表是 GPT 系列、Claude、Gemini、文心一言、通义千问等。大模型的核心能力&#xff1a;1、自然语言理解与生成 2、跨任务泛化 3、…

作者头像 李华
网站建设 2026/6/23 19:27:58

PaperXie 降重复率/AI率功能如何化解学术写作中的“生成式焦虑”:一种面向“学术表达真实性”的智能协作框架——一位研究生的真实实践记录

在生成式人工智能&#xff08;AIGC&#xff09;迅猛发展的今天&#xff0c;学术写作正面临前所未有的伦理挑战。一方面&#xff0c;AI工具能高效辅助内容生成&#xff0c;极大提升写作效率&#xff1b;另一方面&#xff0c;其输出内容往往带有明显的“AI痕迹”&#xff0c;如语…

作者头像 李华
网站建设 2026/6/22 22:48:35

科研文稿 “学术查重的降噪滤波器”:PaperXie 降重降 AI 率如何让重复文本从 “信号杂音” 变 “导师认可的纯净成果”

对科研写作者而言&#xff0c;降重降 AI 率从不是 “改几个词”—— 是学术文稿的 “信号降噪全流程”。重复内容是 “文稿里的杂音干扰”&#xff0c;AI 痕迹是 “信号里的机械失真”&#xff0c;格式乱是 “降噪时丢了核心信息”&#xff0c;过度改写是 “把信号调成了噪音”…

作者头像 李华
网站建设 2026/6/22 21:59:16

八款 AI 文本优化工具能力棱镜:基于“语义保真—AI消除—学科适配—流程嵌入”四维模型的八工具全景评估

随着知网、维普等主流查重系统全面引入“AIGC检测”模块&#xff0c;学术写作进入“重复率”与“AI率”双重考核时代。研究者不再仅需规避文字重复&#xff0c;更需消除AI生成文本的“机器痕迹”&#xff08;如语言模式化、逻辑空洞、缺乏人味&#xff09;。市场涌现众多“降AI…

作者头像 李华