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;
    }
相关推荐
淮北49432 分钟前
STL学习(十一、常用的算数算法和集合算法)
c++·vscode·学习·算法
糖葫芦君37 分钟前
玻尔兹曼分布与玻尔兹曼探索
人工智能·算法·机器学习
摸鱼仙人~39 分钟前
Redis 数据结构全景解析
数据结构·数据库·redis
AA陈超3 小时前
虚幻引擎5 GAS开发俯视角RPG游戏 #06-11:游戏后效果执行
c++·游戏·ue5·游戏引擎·虚幻
天若有情6735 小时前
【python】Python爬虫入门教程:使用requests库
开发语言·爬虫·python·网络爬虫·request
寒水馨6 小时前
Java 17 新特性解析与代码示例
java·开发语言·jdk17·新特性·java17
启山智软6 小时前
选用Java开发商城的优势
java·开发语言
秃然想通6 小时前
掌握Python三大语句:顺序、条件与循环
开发语言·python·numpy
##学无止境##6 小时前
Maven 从入门到精通:Java 项目构建与依赖管理全解析(上)
java·开发语言·maven