• 博客园logo
  • 会员
  • 众包
  • 新闻
  • 博问
  • 闪存
  • 赞助商
  • HarmonyOS
  • Chat2DB
    • 搜索
      所有博客
    • 搜索
      当前博客
  • 写随笔 我的博客 短消息 简洁模式
    用户头像
    我的博客 我的园子 账号设置 会员中心 简洁模式 ... 退出登录
    注册 登录

sm1le

  • 博客园
  • 联系
  • 订阅
  • 管理

公告

View Post

递归实现二叉树前中后遍历

递归三要素:每次写递归想到这三要素
1.确定递归函数的参数以及返回值
2.确定递归的出口
3.确定单层递归的逻辑

二叉树结构体:

struct Treenode{
public:
    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 traverpre(TreeNode* node, vector<int>& res)
    {
        if(!node)
            return;
        res.push_back(node->val);
        traverpre(node->left, res);
        traverpre(node->right, res);
    }
    vector<int> preorderTraversal(TreeNode* root) {
        vector<int> res;
        traverpre(root, res);
        return res;
    }
};

中序遍历:

class Solution {
public:
    void traverord(TreeNode* node, vector<int>& res)
    {
        if(!node)
            return;
        traverord(node->left, res);
        res.push_back(node->val);
        traverord(node->right, res);
    }
    vector<int> inorderTraversal(TreeNode* root) {
        vector<int> res;
        traverord(root, res);
        return res;
    }
};

后序遍历:

class Solution {
public:
    void traverpost(TreeNode* node, vector<int>& res)
    {
        if(!node)
            return;
        traverpost(node->left, res);
        traverpost(node->right, res);
        res.push_back(node->val);
    }
    vector<int> postorderTraversal(TreeNode* root) {
        vector<int> res;
        traverpost(root, res);
        return res;
    }
};

posted on 2022-04-14 11:28  sm1le  阅读(37)  评论(0)    收藏  举报

刷新页面返回顶部
 
博客园  ©  2004-2025
浙公网安备 33010602011771号 浙ICP备2021040463号-3