Leetcode只二叉树中序遍历(python解法)

1.题目描述

示例 1:

复制代码
输入:root = [1,null,2,3]
输出:[1,3,2]

示例 2:

复制代码
输入:root = []
输出:[]

示例 3:

复制代码
输入:root = [1]
输出:[1]
2.解决方法:

中序遍历就是先遍历左子树然后遍历右子树

可以使用栈将左子树所有的根节点的val记录下来,然后在从底部网上遍历,这才是正确的书顺序

此时就可以加上左树和根,此时遍历右子树即可

栈方法:

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 = [] # 存放最终遍历结果

stack = [] # 显式栈,模拟递归调用栈

current = root # 当前正在处理的节点,从根开始

只要栈不为空,或者当前节点不为空,就继续循环

while stack or current:

一路向左,把路径上所有节点压入栈

while current:

stack.append(current)

current = current.left

此时 current 为 None,说明已到达最左叶子的左孩子(空)

弹出栈顶 ------ 这就是当前子树中"最左但未访问"的节点(即该子树的根)

current = stack.pop()

result.append(current.val) # 访问它(加入结果)

转向它的右子树(可能为空,也可能有内容)

current = current.right

return result

递归方法:

def inorderTraversal(root):

if not root: # 基础情况

return []

left_list = inorderTraversal(root.left) # 递归处理左子树

right_list = inorderTraversal(root.right) # 递归处理右子树

return left_list + [root.val] + right_list

相关推荐
无限进步_2 小时前
【C++】反转字符串的进阶技巧:每隔k个字符反转k个
java·开发语言·c++·git·算法·github·visual studio
bnmoel2 小时前
C语言自定义类型:联合和枚举
c语言·开发语言·数据结构·算法
计算机安禾2 小时前
【数据结构与算法】第34篇:选择排序:简单选择排序与堆排序
c语言·开发语言·数据结构·c++·算法·排序算法·visual studio
汀、人工智能11 小时前
[特殊字符] 第40课:二叉树最大深度
数据结构·算法·数据库架构·图论·bfs·二叉树最大深度
沉鱼.4411 小时前
第十二届题目
java·前端·算法
Accerlator11 小时前
2026 年 4 月 1 日电话面试
面试·职场和发展
大熊背12 小时前
ISP Pipeline中Lv实现方式探究之三--lv计算定点实现
数据结构·算法·自动曝光·lv·isppipeline
西岸行者12 小时前
BF信号是如何多路合一的
算法
大熊背13 小时前
ISP Pipeline中Lv实现方式探究之一
算法·自动白平衡·自动曝光