leetcode144. 二叉树的前序遍历

一、题目描述:

给你二叉树的根节点 root ,返回它节点值的 前序 遍历。

二、输入输出实例:

示例 1:

输入:root = [1,null,2,3]
输出:[1,2,3]

示例 2:

输入:root = []
输出:[]

示例 3:

输入:root = [1]
输出:[1]

示例 4:

输入:root = [1,2]
输出:[1,2]

示例 5:

输入:root = [1,null,2]
输出:[1,2]

提示:

  • 树中节点数目在范围 [0, 100] 内
  • -100 <= Node.val <= 100

三、先决知识点: 

四、思路讲解:

4.1递归思路:

  • 先判断当前节点是否为空。
  • 如果为空,直接返回。
  • 如果不为空,将节点值存储到vector中,递归当前节点的左子树和右子树。

4.2循环思路:

  • 创建一个vector对象,用于返回。然后判断根节点是否存在,如果不存在直接返回vector对象。
  • 主要思想是利用栈,将每个节点分为左边和右边处理。
  • 先处理左边,从根节点开始,一直向下找最左节点。期间将所有左节点的指针压栈,将节点值存储到vector中。先忽略所有路径上的右节点。
  • 找到最左节点后,开始出栈每一个左节点,处理左节点的右子树,期间将每一个右子树看作左节点来继续压栈。
  • 如果右节点为空,说明当前左节点已经全部处理完成。出栈下一个左节点,循环即可。
  • 最后,当栈的最后一个左节点被弹出,整个二叉树就被处理为了。

五、C++代码:

5.1递归实现:

    vector<int> preorderTraversal(TreeNode* root)
    {
        vector<int> v;
        preorder(root,v);
        return v;
    }

    void preorder(TreeNode* root,vector<int>& v)
    {
        if(root==nullptr)
            return;
        v.push_back(root->val);
        preorder(root->left,v);
        preorder(root->right,v);
    }

5.2循环实现:

vector<int> preorderTraversal(TreeNode* root)
    {
        vector<int> v;
        if(root==nullptr)
            return v;

        stack<TreeNode*> s;
        while(!s.empty()||root!=nullptr)
        {
            while(root!=nullptr)
            {
                v.push_back(root->val);
                s.push(root);
                root=root->left;
            }
            root=s.top();
            s.pop();
            root=root->right;
        }
        return v;
    }

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-06-19 05:22:01       94 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-06-19 05:22:01       100 阅读
  3. 在Django里面运行非项目文件

    2024-06-19 05:22:01       82 阅读
  4. Python语言-面向对象

    2024-06-19 05:22:01       91 阅读

热门阅读

  1. 音频流采样器类的实现【6】

    2024-06-19 05:22:01       35 阅读
  2. Shellcode详解

    2024-06-19 05:22:01       56 阅读
  3. 在JPA项目启动时新增MySQL字段

    2024-06-19 05:22:01       30 阅读
  4. 访问者模式

    2024-06-19 05:22:01       36 阅读
  5. 使用ReentrantLock和ThreadPoolExecutor模拟抢课

    2024-06-19 05:22:01       53 阅读
  6. 最大子段和问题

    2024-06-19 05:22:01       27 阅读
  7. 探索VtKLoader源码中THREE.BufferGeometry的奥秘

    2024-06-19 05:22:01       22 阅读
  8. 深入解析Postman接口测试工具:功能与应用详解

    2024-06-19 05:22:01       33 阅读