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

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

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

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为节点数

相关推荐
W23035765733 小时前
经典算法:最长上升子序列(LIS)深度解析 C++ 实现
开发语言·c++·算法
minji...4 小时前
Linux 线程同步与互斥(三) 生产者消费者模型,基于阻塞队列的生产者消费者模型的代码实现
linux·运维·服务器·开发语言·网络·c++·算法
语戚5 小时前
力扣 968. 监控二叉树 —— 贪心 & 树形 DP 双解法递归 + 非递归全解(Java 实现)
java·算法·leetcode·贪心算法·动态规划·力扣·
skywalker_115 小时前
力扣hot100-7(接雨水),8(无重复字符的最长子串)
算法·leetcode·职场和发展
bIo7lyA8v6 小时前
算法稳定性分析中的输入扰动建模的技术9
算法
CoderCodingNo6 小时前
【GESP】C++三级真题 luogu-B4499, [GESP202603 三级] 二进制回文串
数据结构·c++·算法
sinat_286945196 小时前
AI Coding 时代的 TDD:从理念到工程落地
人工智能·深度学习·算法·tdd
炽烈小老头7 小时前
【 每天学习一点算法 2026/04/12】x 的平方根
学习·算法
ASKED_20197 小时前
从排序到生成:腾讯广告算法大赛 2025 baseline解读
人工智能·算法