news 2026/5/30 23:53:50

【LeetCode刷题】二叉树的中序遍历

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
【LeetCode刷题】二叉树的中序遍历

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

示例 1:

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

示例 2:

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

示例 3:

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

提示:

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

递归解法

利用递归的 “左→根→右” 顺序遍历,是中序遍历的直观实现。

Python代码

from typing import Optional, List class TreeNode: def __init__(self, val=0, left=None, right=None): self.val = val self.left = left self.right = right class Solution: def inorderTraversal(self, root: Optional[TreeNode]) -> List[int]: result = [] # 递归辅助函数:实现中序遍历「左→根→右」的核心逻辑 def traverse(node: Optional[TreeNode]): if node: # 节点非空时才遍历,递归终止条件:node is None traverse(node.left) # 第一步:遍历左子树 result.append(node.val) # 第二步:访问当前根节点 traverse(node.right) # 第三步:遍历右子树 traverse(root) # 从根节点开始递归遍历 return result if __name__ == "__main__": # 实例化解题类 sol = Solution() # 示例1:构建树 [1,null,2,3] → 输出 [1,3,2] root1 = TreeNode(1) root1.right = TreeNode(2) root1.right.left = TreeNode(3) print("示例1输出:", sol.inorderTraversal(root1)) print("预期结果:", [1, 3, 2]) print("-" * 30) # 示例2:构建空树 [] → 输出 [] root2 = None print("示例2输出:", sol.inorderTraversal(root2)) print("预期结果:", []) print("-" * 30) # 示例3:构建树 [1] → 输出 [1] root3 = TreeNode(1) print("示例3输出:", sol.inorderTraversal(root3)) print("预期结果:", [1])

LeetCode提交代码

# Definition for a binary tree node. # class TreeNode: # def __init__(self, val=0, left=None, right=None): # self.val = val # self.left = left # self.right = right class Solution: def inorderTraversal(self, root: Optional[TreeNode]) -> List[int]: result = [] # 递归辅助函数:实现“左→根→右”的遍历逻辑 def traverse(node: Optional[TreeNode]): if node: traverse(node.left) # 先遍历左子树 result.append(node.val) # 再访问当前根节点 traverse(node.right) # 最后遍历右子树 traverse(root) return result

程序运行截图展示

总结

本文介绍了二叉树中序遍历的递归实现方法。中序遍历按照"左子树→根节点→右子树"的顺序访问节点。通过Python代码演示了递归解法,定义了一个辅助函数traverse来实现这一逻辑:先递归遍历左子树,然后访问当前节点值,最后递归遍历右子树。提供了三个测试用例验证正确性:包含单节点树、空树和典型二叉树的情况。时间复杂度为O(n),空间复杂度为O(n)(递归栈空间)。该方法直观体现了中序遍历的定义,是解决此类问题的经典递归范式。

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

计算机Java毕设实战-基于springboo的社团成员活动策划组织管理系统(【完整源码+LW+部署说明+演示视频,全bao一条龙等】

博主介绍&#xff1a;✌️码农一枚 &#xff0c;专注于大学生项目实战开发、讲解和毕业&#x1f6a2;文撰写修改等。全栈领域优质创作者&#xff0c;博客之星、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java、小程序技术领域和毕业项目实战 ✌️技术范围&#xff1a;&am…

作者头像 李华
网站建设 2026/5/28 18:22:23

当系统出现找不到msvcr120.dll文件问题 免费下载方法分享

在使用电脑系统时经常会出现丢失找不到某些文件的情况&#xff0c;由于很多常用软件都是采用 Microsoft Visual Studio 编写的&#xff0c;所以这类软件的运行需要依赖微软Visual C运行库&#xff0c;比如像 QQ、迅雷、Adobe 软件等等&#xff0c;如果没有安装VC运行库或者安装…

作者头像 李华
网站建设 2026/5/28 12:20:58

2026年高效降低AI率工具:这些免费降AI率工具实测,有效降AI率高达60%

一、 2026年了&#xff0c;别让“AI率”卡住你的学位证说真的&#xff0c;现在的毕业季太难了。学校查重系统升级了。以前只查复制比。现在还要查论文降aigc率。很多同学都在问我。明明是自己写的&#xff0c;怎么也被标红&#xff1f;或者用AI润色了一段&#xff0c;直接飙到6…

作者头像 李华
网站建设 2026/5/28 22:53:48

深度学习篇---随机森林通俗理解

核心比喻&#xff1a;森林与委员会 想象一下&#xff0c;你现在有一个难题&#xff08;比如&#xff1a;判断一个水果是苹果还是橙子&#xff09;&#xff0c;你自己拿不准主意。你会怎么办&#xff1f; 一个聪明的方法是&#xff1a;去问一群人&#xff0c;然后采纳大多数人…

作者头像 李华
网站建设 2026/5/29 0:07:28

社会网络仿真软件:NetLogo_(19).社会网络仿真的伦理与法律问题

社会网络仿真的伦理与法律问题 在进行社会网络仿真时&#xff0c;伦理与法律问题不容忽视。这些问题不仅关系到仿真模型的准确性&#xff0c;还直接影响到仿真结果的应用和解释。本节将详细探讨这些伦理与法律问题&#xff0c;包括数据隐私、知情同意、模型的公平性和透明度&a…

作者头像 李华