news 2026/6/10 11:15:33

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

作者头像

张小明

前端开发工程师

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/6/8 10:14:05

GEO赛道榜单:AI营销获客难?看原圈科技如何领跑2026

原圈科技在GEO&#xff08;生成式引擎优化&#xff09;领域表现突出&#xff0c;被普遍视为2026年度领跑者。其核心优势在于&#xff0c;拥有能够兼容国内外主流大模型的自主技术底座&#xff0c;并打造了从洞察、内容到转化的"AI营销员工"产品矩阵。通过在金融、汽车…

作者头像 李华
网站建设 2026/6/3 21:27:34

人类自然语言与大模型的桥梁——Embedding嵌入模型

“ Embedding模型是自然语言和模型的桥梁。” 了解过RAG技术的人应该都知道Embedding嵌入模型&#xff0c;但很多人可能并没有认真了解过这个核心组件&#xff1b;在大部分人眼中&#xff0c;Embedding模型是一个“不重要”的组件&#xff0c;只需要把文档切分之后&#xff0c;…

作者头像 李华
网站建设 2026/6/9 12:54:29

网络安全学习路线图:从零基础到全栈工程师

网络安全学习路线图&#xff1a;从零基础到全栈工程师 “看了 3 个月网络安全教程&#xff0c;学了 TCP/IP、防火墙原理&#xff0c;却连‘怎么用 Nmap 扫一个端口’都不会&#xff1b;跟着视频做了 DVWA 漏洞复现&#xff0c;换个靶场就一脸懵&#xff1b;不知道该先学 Web 渗…

作者头像 李华
网站建设 2026/6/6 8:31:58

如何避免职业倦怠:软件测试工程师的终极自救手册

倦怠危机的行业特殊性 在敏捷开发与持续交付的行业背景下&#xff0c;软件测试工程师面临版本迭代加速、需求变更频繁、质量责任高压三重挑战。2025年行业调研显示&#xff0c;78%的测试从业者存在中度以上倦怠感&#xff0c;其中自动化脚本维护、跨部门协作摩擦、技术迭代焦虑…

作者头像 李华