news 2026/3/25 20:07:36

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

作者头像

张小明

前端开发工程师

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/3/15 17:05:55

Alexa Fluor 647-LNT,Alexa Fluor 647标记乳糖-N-四糖,红光荧光染料

Alexa Fluor 647-LNT&#xff0c;Alexa Fluor 647标记乳糖-N-四糖&#xff0c;红光荧光染料Alexa Fluor 647-LNT 是一种功能化荧光糖类分子&#xff0c;由红光荧光染料 Alexa Fluor 647 与 乳糖-N-四糖&#xff08;Lacto-N-tetraose, LNT&#xff09; 通过共价偶联形成。该分子…

作者头像 李华
网站建设 2026/3/25 5:42:46

不仅仅是浏览器渲染:揭秘 Botasaurus 高效的 HTTP 请求封装

在现代网页爬虫与自动化领域&#xff0c;开发者常常面临一个“鱼与熊掌不可兼得”的困境&#xff1a;使用 Headless 浏览器&#xff08;如 Playwright 或 Selenium&#xff09;虽然能轻松应对复杂的 JavaScript 渲染和反爬校验&#xff0c;但资源消耗巨大、速度缓慢&#xff1b…

作者头像 李华
网站建设 2026/3/25 11:21:24

深入 TCP 核心:握手、挥手、滑动窗口与并发服务器实战

一、 连接的诞生与消亡 1. 三次握手 (The 3-Way Handshake) 发生时机:connect() 调用时。 本质:双方确认对方的发送和接收能力正常,并同步初始序列号 (ISN)。 第一次:客户端发送 SYN=1, seq=J。(我想连你) 第二次:服务器回复 SYN=1, ACK=1, ack=J+1, seq=K。(收到,我…

作者头像 李华
网站建设 2026/3/15 21:00:13

java 环境配置(详细教程)

Java 环境配置详细教程&#xff08;2025–2026 最新主流方式&#xff09; 以下教程主要针对 Windows、macOS、Linux&#xff08;Ubuntu/Debian/CentOS&#xff09; 三种主流操作系统&#xff0c;2025–2026 年最推荐的配置方式。 目前&#xff08;2026年初&#xff09;最推荐…

作者头像 李华