【递归】4.二叉树的前序遍历

1 题目解析

题目链接:二叉树的前序遍历

题目描述如下:

先回顾一下,二叉树的前序遍历的过程是:先遍历根,再遍历左子树,最后遍历右子树。 所以顺序就是:根,左子树,右子树

理清之后,继续回到之前的三步:

复制代码
第一步:挖掘出相同的子问题  (关系到具体函数头的设计)
第二步:只关心具体子问题做了什么  (关系到具体函数体怎么写,是一个宏观的过程)
第三步:找到递归的出口,防止死递归  (关系到如何跳出递归)

相同的子问题:遍历根,左子树,右子树
递归的出口:当根为空的时候递归就退出
具体的子问题做了什么:遍历根,接下来的事情交给左子树,再交给右子树

++函数头该如何写?++

下面是leetcode提供的接口:

cpp 复制代码
    vector<int> preorderTraversal(TreeNode* root) {
    }

可以看到传递的参数是TreeNode* root, 而vector<int>是返回值。所以我们函数头的参数必须包含两个,分别是TreeNode* rootvector<int>类型的参数。

例如下面这样:

cpp 复制代码
void preorder(TreeNode* root, vector<int> &res)

++函数体该如何写?++

如何写函数体,就需要关心具体的操作过程。在二叉树的前序遍历上,具体的过程就是:先遍历根,再遍历左子树,最后遍历右子树。

函数的实现:

cpp 复制代码
void preorder(TreeNode* root, vector<int> &res)
    {
        //递归的出口
        if (root == nullptr)
            return;
        
        //1.遍历根
        res.push_back(root->val);
        //2.遍历左子树
        preorder(root->left, res);
        //3.遍历右子树
        preorder(root->right, res);
    }

2 总结

全部的代码如下:

cpp 复制代码
class Solution {
public:
    vector<int> preorderTraversal(TreeNode* root) {
        vector<int> res;
        preorder(root, res);
        return res;
    }

    //函数的具体操作
    void preorder(TreeNode* root, vector<int> &res)
    {
        //递归的出口
        if (root == nullptr)
            return;
        
        //1.遍历根
        res.push_back(root->val);
        //2.遍历左子树
        preorder(root->left, res);
        //3.遍历右子树
        preorder(root->right, res);
    }
};
相关推荐
前端摸鱼匠3 小时前
【AI大模型春招面试题11】什么是模型的“涌现能力”(Emergent Ability)?出现条件是什么?
人工智能·算法·ai·自然语言处理·面试·职场和发展
MORE_773 小时前
leecode-合并区间-贪心算法
算法·贪心算法
2401_873204653 小时前
分布式系统安全通信
开发语言·c++·算法
sw1213894 小时前
C++中的代理模式实战
开发语言·c++·算法
ballball~~5 小时前
ISP-CCM(Color Correction Matrix)
图像处理·数码相机·算法
Sunshine for you5 小时前
实时操作系统中的C++
开发语言·c++·算法
中科院提名者6 小时前
BPE 算法的硬核拆解——理解词表(Vocabulary)是如何从零训练出来的,以及字符串是如何被切碎的
算法
「QT(C++)开发工程师」6 小时前
C++11三大核心特性深度解析:类型特征、时间库与原子操作
java·c++·算法
乐分启航6 小时前
SliMamba:十余K参数量刷新SOTA!高光谱分类的“降维打击“来了
java·人工智能·深度学习·算法·机器学习·分类·数据挖掘
你真是饿了8 小时前
算法专题二:滑动窗口
算法