news 2026/4/8 19:10:49

【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/3/16 16:19:40

ubuntu通过windows主机访问网络

背景&#xff1a;校园网限制用户连接数量 方法&#xff1a;用usb网卡。用一台windows主机连接校园网登录&#xff0c;插usb网卡连网线到ubuntu机器&#xff1b;ubuntu机器不需要什么额外配置&#xff0c;windows更改网络适配器设置&#xff0c;把 校园网连接->属性->共享…

作者头像 李华
网站建设 2026/4/5 20:13:36

Doris与Flink整合实战:构建流批一体的大数据处理平台

Doris与Flink整合实战&#xff1a;构建流批一体的大数据处理平台 关键词&#xff1a;Doris、Flink、流批一体、大数据处理平台、实时计算 摘要&#xff1a;本文聚焦于Doris与Flink的整合&#xff0c;旨在构建流批一体的大数据处理平台。详细介绍了Doris和Flink的核心概念及两者…

作者头像 李华
网站建设 2026/4/6 20:26:07

【C标准库】一文吃透 C 语言 assert 断言

文章目录一、assert 是什么&#xff1f;二、基本语法和使用步骤2.1 核心语法2.2 最简单的示例三、assert 的工作机制3.1 如何定义 NDEBUG&#xff08;关闭断言&#xff09;&#xff1f;四、assert 的适用场景五、assert 的使用禁忌禁忌1&#xff1a;断言中包含有副作用的表达式…

作者头像 李华
网站建设 2026/4/3 4:43:55

社会网络仿真软件:NetLogo_(17).NetLogo教学与研究资源

NetLogo教学与研究资源 在社会网络仿真的研究和教学中&#xff0c;NetLogo 提供了丰富的资源和工具&#xff0c;帮助用户更好地理解和应用这一强大的仿真平台。本节将详细介绍 NetLogo 的教学与研究资源&#xff0c;包括官方文档、示例模型、在线教程、社区支持以及第三方资源等…

作者头像 李华