【力扣-94.二叉树的中序遍历】Python笔记

彻底搞懂二叉树遍历:从递归到迭代,前中后序一网打尽

摘要:还在为二叉树遍历的迭代写法头秃吗?本文带你彻底吃透前序、中序、后序遍历的迭代逻辑。通过"统一迭代法"的思路,配合清晰的代码注释和对比总结,助你轻松搞定 LeetCode 相关题目,从此面试不慌!


📚 核心知识点:为什么要学迭代法?

在刷二叉树题目时,递归(Recursion) 写法通常最简单,几行代码就能搞定。但在面试中,面试官往往会追问:"能不能用 迭代(Iteration) 实现?"为什么?因为递归本质上是利用系统的函数调用栈 ,如果树太深,容易导致栈溢出。而迭代法是手动维护一个栈(Stack) ,不仅更安全,还能体现你对遍历过程底层逻辑的深刻理解。

二叉树的三种遍历顺序:

  • 前序 (Pre-order) :中 → 左 → 右
  • 中序 (In-order) :左 → 中 → 右
  • 后序 (Post-order) :左 → 右 → 中

💻 代码实战:迭代法三部曲

我们将使用 Python 来实现。这里的核心思想是:用栈来模拟系统递归的过程

1. 前序遍历 (Pre-order Traversal)

逻辑

前序遍历是"中左右"。因为栈是"后进先出"的,所以我们在压栈时,要先压右孩子,再压左孩子,这样弹出的时候就是"中 → 左 → 右"了。

python 复制代码
class Solution:
    def preorderTraversal(self, root: Optional[TreeNode]) -> List[int]:
        if not root:
            return []
        
        res = []
        stack = [root]  # 1. 根节点先入栈
        
        while stack:
            # 2. 弹出栈顶元素(中间节点)
            node = stack.pop()
            res.append(node.val)  # 访问中间节点
            
            # 3. 注意顺序:先右后左(因为栈是后进先出)
            if node.right:
                stack.append(node.right)
            if node.left:
                stack.append(node.left)
                
        return res
2. 中序遍历 (In-order Traversal)

逻辑

中序遍历是"左中右"。这比较特殊,因为我们要先一路向左走到底,把路上的节点都压进栈,但不访问。等走不动了,再从栈里弹出一个节点访问,然后转向它的右孩子。

python 复制代码
class Solution:
    def inorderTraversal(self, root: Optional[TreeNode]) -> List[int]:
        res = []
        stack = []
        cur = root  # 指针指向当前节点
        
        # 只要当前节点不为空,或者栈里还有节点,就继续循环
        while cur or stack:
            if cur:
                # 1. 一路向左,把遇到的节点全部入栈
                stack.append(cur)
                cur = cur.left
            else:
                # 2. 走到最左边了,开始处理栈顶节点(中间节点)
                cur = stack.pop()
                res.append(cur.val)  # 访问中间节点
                
                # 3. 转向右孩子,继续上述过程
                cur = cur.right
                
        return res
3. 后序遍历 (Post-order Traversal)

逻辑

后序是"左右中"。直接写"左右中"比较难,我们可以利用前序遍历的思路,改成"中右左",最后把结果数组反转一下,就变成了"左右中"。

python 复制代码
class Solution:
    def postorderTraversal(self, root: Optional[TreeNode]) -> List[int]:
        if not root:
            return []
        
        res = []
        stack = [root]
        
        while stack:
            node = stack.pop()
            res.append(node.val)  # 访问中间节点
            
            # 注意顺序:先左后右(这样弹出是 中→右→左)
            if node.left:
                stack.append(node.left)
            if node.right:
                stack.append(node.right)
        
        # 最后反转结果,变成 左→右→中
        return res[::-1] 

📊 统一对比总结(建议收藏)

为了方便记忆,我们可以把迭代法分为两类:简单调整法 (前序/后序)和 指针法(中序)。

遍历类型 核心逻辑 关键点
前序 中 → 左 → 右 栈:先入右,后入左。
中序 左 → 中 → 右 指针 cur 一路向左入栈,到底了再弹出访问,并转向右。
后序 左 → 右 → 中 修改前序逻辑:中 → 右 → 左,最后将结果 res 反转。

📌 作者寄语

二叉树遍历是数据结构的基石。前序和后序的迭代写法非常相似,只是入栈顺序和结果处理不同;而中序遍历因为访问顺序(左中右)和处理顺序(中左右)不一致,所以需要指针辅助。掌握了这三种写法,以后遇到二叉树的题目,不管是层序遍历还是路径总和,你都能游刃有余地写出非递归解法啦!

相关推荐
小小龙学IT5 小时前
Apache Airflow 2.x 深度指南:用 Python 编排一切的现代化工作流引擎
开发语言·python·apache
你是个什么橙6 小时前
Python入门学习2:Python 基础语法全解析——从代码结构到输入输出
开发语言·python·学习
小白学大数据6 小时前
Python + 大模型行业资讯自动化摘要流水线完整工程实现方案
开发语言·python·自动化
秋波。未央6 小时前
Java Agent 开发 · Day 1 学习笔记(含作业完整标准答案)
java·笔记·学习
凌波粒6 小时前
LeetCode--491.递增子序列(回溯算法)
数据结构·算法·leetcode
beethobe6 小时前
PythonQt 学习之旅(一):从零构建 C++ 与 Python 的桥梁
c++·python·学习
广州智造6 小时前
如何在HyperMesh运行Python脚本及查找Python API帮助
python·仿真·cae·hypermesh·optistruct
cooldog123pp6 小时前
cplex完全安装手册,适配matlab和python!
人工智能·python·matlab·cplex
TechWayfarer6 小时前
苏超赛事网站安全防护:WAF、DDoS与仿冒页面如何联动治理
网络·python·安全·flask·ddos
中屹指纹浏览器6 小时前
2026指纹浏览器字体指纹、字体渲染偏差检测与全维度虚拟字体池搭建方案
经验分享·笔记