LeetCode - 144. 二叉树的前序遍历

目录

题目

什么是前序遍历

递归的写法

非递归的写法

思路

实现


题目

144. 二叉树的前序遍历 - 力扣(LeetCode)

什么是前序遍历

前序遍历(Preorder Traversal)是一种遍历树形结构的方法,特别是在二叉树中常用。它的遍历顺序为:

  • 先访问根节点
  • 然后递归地前序遍历左子树
  • 最后递归地前序遍历右子树

这种遍历方式也称为"深度优先遍历"(DFS)的一种形式。

示例

对于以下二叉树:

复制代码
    A
   / \
  B   C
 / \   \
D   E   F

前序遍历的结果是:A → B → D → E → C → F

递归的写法

cpp 复制代码
vector<int> preorderTraversal(TreeNode* root) {
    vector<int> result;
    preorder(root, result);
    return result;
}

void preorder(TreeNode* node, vector<int>& result) {
    if (node == nullptr) {
        return;
    }
    
    // 前序遍历顺序:根 -> 左 -> 右
    result.push_back(node->val);  // 访问根节点
    preorder(node->left, result);  // 递归访问左子树
    preorder(node->right, result);  // 递归访问右子树
}

非递归的写法

思路

初始化:

  • 创建一个空的结果数组 result 用于存储遍历结果
  • 创建一个栈 stack 用于存储待访问的节点
  • 检查根节点是否为空,如果为空直接返回空结果

算法流程:

  • 将根节点压入栈中
  • 当栈不为空时,重复以下步骤:

弹出栈顶节点 current

将 current 的值加入结果数组(访问当前节点)

关键点:先将右子节点压栈,再将左子节点压栈

  • 这是因为栈是后进先出(LIFO)的数据结构
  • 我们希望左子节点先于右子节点被处理,所以右子节点要先入栈

继续循环,直到栈为空

为什么这样工作:

  • 每次我们弹出一个节点,立即访问它(符合前序的"先访问根"原则)
  • 然后将其子节点以"右-左"顺序压栈,这样出栈顺序就是"左-右"
  • 这保证了对于每个子树,我们都是按照"根-左-右"的顺序访问

复杂度分析:

  • 时间复杂度:O(n),其中 n 是树中的节点数,每个节点被访问一次
  • 空间复杂度:O(h),其中 h 是树的高度,最坏情况下为 O(n)(树完全不平衡)

实现

cpp 复制代码
vector<int> preorderTraversal(TreeNode* root) {
    vector<int> result;
    if (root == nullptr) {
        return result;
    }
    
    stack<TreeNode*> st;
    st.push(root);
    
    while (!st.empty()) {
        // 弹出栈顶节点并访问
        TreeNode* node = st.top();
        st.pop();
        result.push_back(node->val);
        
        // 注意:先压入右子节点,再压入左子节点
        // 这样出栈时才会先处理左子节点(栈是后进先出)
        if (node->right) {
            st.push(node->right);
        }
        if (node->left) {
            st.push(node->left);
        }
    }
    
    return result;
}
相关推荐
鱼跃鹰飞几秒前
Leetcode279:完全平方数
数据结构·算法·leetcode·面试
小龙报几秒前
【数据结构与算法】单链表核心精讲:从概念到实战,吃透指针与动态内存操作
c语言·开发语言·数据结构·c++·人工智能·算法·链表
long3162 分钟前
合并排序 merge sort
java·数据结构·spring boot·算法·排序算法
格林威3 分钟前
Baumer相机碳纤维布纹方向识别:用于复合材料铺层校验的 5 个核心技巧,附 OpenCV+Halcon 实战代码!
人工智能·数码相机·opencv·算法·计算机视觉·视觉检测
范纹杉想快点毕业4 分钟前
STM32单片机与ZYNQ PS端 中断+状态机+FIFO 综合应用实战文档(初学者版)
linux·数据结构·数据库·算法·mongodb
近津薪荼12 分钟前
递归专题(1)——汉诺塔
c++·学习·算法
总斯霖15 分钟前
HDU 4857 - 逃生 题解
算法
-To be number.wan16 分钟前
算法学习日记 | 模拟
c++·学习·算法
Blossom.11817 分钟前
从“金鱼记忆“到“超级大脑“:2025年AI智能体记忆机制与MoE架构的融合革命
人工智能·python·算法·架构·自动化·whisper·哈希算法
金枪不摆鳍17 分钟前
算法-贪心算法
算法·贪心算法