news 2026/5/1 7:12:59

二叉树的前序、中序、后序遍历分别是什么?各自有什么应用场景?

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
二叉树的前序、中序、后序遍历分别是什么?各自有什么应用场景?

二叉树的前序、中序、后序遍历是三种经典的深度优先遍历(DFS)方式,它们的区别仅在于访问根节点的时机不同。下面用一张表+详细说明帮你彻底搞懂:


📊 一、核心定义对比

表格

遍历类型访问顺序口诀根节点位置
前序遍历根 → 左子树 → 右子树根左右最先
中序遍历左子树 → 根 → 右子树左根右中间
后序遍历左子树 → 右子树 → 根左右根最后

✅ 共同点:

  • 都是递归结构(每个子树都按相同规则处理)
  • 时间复杂度:O(n)(每个节点访问一次)
  • 空间复杂度:O(h)(h = 树高,递归栈或显式栈的深度)

🌰 二、举例说明(同一棵树)

以这棵二叉树为例:

A / \ B C / \ \ D E F

表格

遍历类型遍历结果过程简述
前序A → B → D → E → C → F先记根A,再钻左子树(B→D→E),最后右子树(C→F)
中序D → B → E → A → C → F先钻到最左(D),回溯记B,再右(E),回溯记A,再处理右子树(C→F)
后序D → E → B → F → C → A先处理完左右子树(D,E,B 和 F,C),最后记根A

⚙️ 三、各自优点与典型应用场景

1.前序遍历(Pre-order)
  • 优点
    • 先处理根节点,适合需要“自顶向下”操作的场景
    • 结构清晰,易于序列化/反序列化
  • 典型应用
    复制二叉树(先创建根,再递归复制左右子树)
    树的序列化(如 LeetCode 的[1,2,3,null,null,4,5]格式)
    表达式树 → 前缀表达式(如+ 1 * 2 3
    目录结构导出(先输出父文件夹,再子文件夹)
2.中序遍历(In-order)
  • 优点
    • 对二叉搜索树(BST)天然有序
    • 能反映“左 < 根 < 右”的逻辑顺序
  • 典型应用
    BST 升序输出(验证 BST、找第 K 小元素)
    表达式树 → 中缀表达式(如(1 + (2 * 3)),需加括号)
    数据库索引遍历(B+树的中序即有序数据)
    DOM 树节点顺序访问(前端开发)
3.后序遍历(Post-order)
  • 优点
    • 先处理子节点,再处理根节点,适合“自底向上”计算
    • 安全释放资源(子节点先销毁)
  • 典型应用
    删除二叉树(先删左右子树,再删根,避免悬空指针)
    计算目录大小(先算子目录大小,再累加到父目录)
    表达式树 → 后缀表达式(逆波兰)(如1 2 3 * +
    编译器语法分析(先处理子表达式,再处理运算符)

💡 四、如何选择?

需求场景推荐遍历
需要先知道根节点信息前序
处理 BST 或需要有序结果中序
需要子节点结果才能处理根节点后序

🛠 五、代码模板(Python 递归)

# 前序遍历 def preorder(root): if not root: return [] return [root.val] + preorder(root.left) + preorder(root.right) # 中序遍历 def inorder(root): if not root: return [] return inorder(root.left) + [root.val] + inorder(root.right) # 后序遍历 def postorder(root): if not root: return [] return postorder(root.left) + postorder(root.right) + [root.val]

✅ 总结一句话:

  • 前序做事先定调(先处理根)→ 用于复制、序列化
  • 中序做事讲顺序(左根右)→ 用于排序、表达式
  • 后序做事收尾好(后处理根)→ 用于删除、计算

掌握这三种遍历的本质区别和应用场景,就掌握了二叉树操作的“任督二脉”! 🌟

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

建站知识:域名/ 空间/ IP/ 端口之间的关系

域名、空间、IP、端口之间的关系&#xff08;建站完整图解&#xff0c;2026 年视角&#xff09; 建站最基础的四要素就是这四个&#xff1a;域名、空间&#xff08;服务器/主机&#xff09;、IP 地址、端口。它们的关系可以用一句话概括&#xff1a; 域名 → 解析到 → IP地址…

作者头像 李华
网站建设 2026/5/1 4:46:47

为什么AI开发者必须规划职业转型?2026年生存法则

一、AI大模型崛起&#xff1a;软件测试领域的颠覆性变革 当前&#xff0c;AI大模型技术正重塑软件开发全流程&#xff0c;软件测试从业者首当其冲面临职业挑战。随着AI代码生成工具的普及&#xff0c;传统测试任务如重复性用例执行、缺陷检测等正被自动化取代。例如&#xff0…

作者头像 李华