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;
    }
相关推荐
San30.6 分钟前
深入理解 JavaScript OOP:从一个「就地编辑组件」看清封装、状态与原型链
开发语言·前端·javascript·ecmascript
郑州光合科技余经理10 分钟前
基于PHP:海外版同城O2O系统多语言源码解决方案
java·开发语言·git·spring cloud·uni-app·php·uniapp
zmzb010313 分钟前
C++课后习题训练记录Day43
开发语言·c++
月明长歌22 分钟前
【码道初阶】一道经典简单题:多数元素(LeetCode 169)|Boyer-Moore 投票算法详解
算法·leetcode·职场和发展
wadesir27 分钟前
C语言模块化设计入门指南(从零开始构建清晰可维护的C程序)
c语言·开发语言·算法
t1987512830 分钟前
MATLAB水声信道仿真程序
开发语言·算法·matlab
赖small强38 分钟前
【Linux C/C++开发】 GCC -g 调试参数深度解析与最佳实践
linux·c语言·c++·gdb·-g
前端之虎陈随易1 小时前
MoonBit内置数据结构详解
数据结构·数据库·redis
qq_12498707531 小时前
基于SpringBoot+vue的小黄蜂外卖平台(源码+论文+部署+安装)
java·开发语言·vue.js·spring boot·后端·mysql·毕业设计
CAE虚拟与现实1 小时前
C/C++中“静态链接(Static Linking)” 和 “动态链接(Dynamic Linking)释疑
开发语言·c++·dll·动态链接库·lib库