力扣二叉树的前序中序后序遍历总结

二叉树的前中后序遍历,需要我们牢牢掌握。

力扣有题目,我们借这三个题目牢牢弄清楚关于整个二叉树的前中后序遍历。

144. 二叉树的前序遍历
94. 二叉树的中序遍历
145. 二叉树的后序遍历

首先我们要清楚,所谓前序,中序和后序是三种不同的二叉树的遍历方式。

前序

前序就是先遍历根节点再遍历左节点(有子树遍历子树)最后遍历右节点(有子树遍历子树)

口诀即为:根左右。

重点在于写代码:

cpp 复制代码
/**
 * Definition for a binary tree node.
 * struct TreeNode {
 *     int val;
 *     TreeNode *left;
 *     TreeNode *right;
 *     TreeNode() : val(0), left(nullptr), right(nullptr) {}
 *     TreeNode(int x) : val(x), left(nullptr), right(nullptr) {}
 *     TreeNode(int x, TreeNode *left, TreeNode *right) : val(x), left(left), right(right) {}
 * };
 */
class Solution {
public:

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

    }
    vector<int> preorderTraversal(TreeNode* root) {
        vector<int> ans;
        //ans.push_back(root->val);
       preorder(root,ans);
        return ans;
    }
};

写代码的时候要注意用递归的写法来写,按照根左右的顺序递归调用。

接着是中序

中序

中序就是左根右,和前序的解释一样,无非是顺序不一样。

c++ 复制代码
/**
 * Definition for a binary tree node.
 * struct TreeNode {
 *     int val;
 *     TreeNode *left;
 *     TreeNode *right;
 *     TreeNode() : val(0), left(nullptr), right(nullptr) {}
 *     TreeNode(int x) : val(x), left(nullptr), right(nullptr) {}
 *     TreeNode(int x, TreeNode *left, TreeNode *right) : val(x), left(left), right(right) {}
 * };
 */
class Solution {
public:
     void inorder(TreeNode* root,vector<int>& ans)
     {
        if(root==nullptr)
        {
           return;
        }
        else
        {
           inorder(root->left,ans);
           ans.push_back(root->val);
           inorder(root->right,ans);
        }
     }
    vector<int> inorderTraversal(TreeNode* root) {
        vector<int> ans;
        inorder(root,ans);
        return ans;
    }
};

后序

后序就是左右根

cpp 复制代码
/**
 * Definition for a binary tree node.
 * struct TreeNode {
 *     int val;
 *     TreeNode *left;
 *     TreeNode *right;
 *     TreeNode() : val(0), left(nullptr), right(nullptr) {}
 *     TreeNode(int x) : val(x), left(nullptr), right(nullptr) {}
 *     TreeNode(int x, TreeNode *left, TreeNode *right) : val(x), left(left), right(right) {}
 * };
 */
class Solution {
public:
   void postorder(TreeNode* root,vector<int>& ans)
   {
        if(root==nullptr)
        {
            return;
        }
        else
        {
            postorder(root->left,ans);
            postorder(root->right,ans);
            ans.push_back(root->val);
        }
   }
    vector<int> postorderTraversal(TreeNode* root) {
        //左右根
        vector<int> ans;
        postorder(root,ans);
        return ans;
    }
};

写代码也是严格的按照遍历顺序的方式用递归的写法写的。

除此之外也可以用栈来写,但递归的代码都比较简练,一般都用递归来写。

时间复杂度为O(n)n为节点数

相关推荐
虾..14 小时前
Linux 简单日志程序
linux·运维·算法
Trent198514 小时前
影楼精修-眼镜祛反光算法详解
图像处理·人工智能·算法·计算机视觉·aigc
蓝色汪洋14 小时前
经典修路问题
开发语言·c++·算法
csuzhucong14 小时前
122魔方、123魔方
算法
Salt_072814 小时前
DAY 40 早停策略和模型权重的保存
人工智能·python·算法·机器学习
卜锦元14 小时前
Golang后端性能优化手册(第三章:代码层面性能优化)
开发语言·数据结构·后端·算法·性能优化·golang
Binky67814 小时前
力扣--回溯篇(2)
算法·leetcode·职场和发展
De-Alf15 小时前
Megatron-LM学习笔记(6)Megatron Model Attention注意力与MLA
笔记·学习·算法·ai
2401_8414956415 小时前
【LeetCode刷题】打家劫舍
数据结构·python·算法·leetcode·动态规划·数组·传统dp数组
冰西瓜60015 小时前
STL——vector
数据结构·c++·算法