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

相关推荐
一只幸运猫.21 分钟前
2026Java 后端面试完整版|八股简答 + AI 大模型集成技术(最新趋势)
人工智能·面试·职场和发展
Old Uncle Tom22 分钟前
OpenClaw 记忆系统 -- 记忆预加载
java·数据结构·算法·agent
会编程的土豆32 分钟前
洛谷题单入门1 顺序结构
数据结构·算法·golang
生信碱移34 分钟前
PACells:这个方法可以鉴定疾病/预后相关的重要细胞亚群,作者提供的代码流程可以学习起来了,甚至兼容转录组与 ATAC 两种数据类型!
人工智能·学习·算法·机器学习·数据挖掘·数据分析·r语言
智者知已应修善业1 小时前
【51单片机中的打飞机设计】2023-8-25
c++·经验分享·笔记·算法·51单片机
圣保罗的大教堂2 小时前
leetcode 1855. 下标对中的最大距离 中等
leetcode
智者知已应修善业3 小时前
【51单片机按键调节占空比3位数码管显示】2023-8-24
c++·经验分享·笔记·算法·51单片机
.5484 小时前
## Sorting(排序算法)
python·算法·排序算法
wuweijianlove4 小时前
算法的平均复杂度建模与性能回归分析的技术7
算法·数据挖掘·回归
子琦啊4 小时前
【算法复习】字符串 | 两个底层直觉,吃透高频题
linux·运维·算法