当前位置: 首页 > news >正文

二叉树的前序中序后序遍历

一、前序遍历

144. Binary Tree Preorder Traversal

递归代码实现:

/**
 * 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:
    vector<int> preorderTraversal(TreeNode* root) {
        vector<int> preOrder;
        doPreOrderTraversal(root,preOrder);
        return preOrder;
    }
    void doPreOrderTraversal(TreeNode* root,vector<int> &preOrder){
        if(root){
            preOrder.push_back(root->val);
            doPreOrderTraversal(root->left,preOrder);
            doPreOrderTraversal(root->right,preOrder);
        }
    }
};

二、中序遍历

94. Binary Tree Inorder Traversal

递归代码实现

/**
 * 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:
    vector<int> inorderTraversal(TreeNode* root) {
        vector<int> inOrder;
        doInorderTraversal(root,inOrder);
        return inOrder;
    }
    void doInorderTraversal(TreeNode* root,vector<int> &inOrder){
        if(root){
            doInorderTraversal(root->left,inOrder);
            inOrder.push_back(root->val);
            doInorderTraversal(root->right,inOrder);
        }
    }
};

三、后续遍历

145. Binary Tree Postorder Traversal

后续代码实现

/**
 * 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:
    vector<int> postorderTraversal(TreeNode* root) {
        vector<int> postOrder;
        doPostOrderTraversal(root,postOrder);
        return postOrder;
    }
    void doPostOrderTraversal(TreeNode* root,vector<int> &postOrder){
        if(root){
            doPostOrderTraversal(root->left,postOrder);
            doPostOrderTraversal(root->right,postOrder);
            postOrder.push_back(root->val);
        }
    }
};
http://www.dtcms.com/a/113050.html

相关文章:

  • DeFi漏洞利用与安全防护
  • Oracle数据库数据编程SQL<8 文本编辑器Notepad++和UltraEdit(UE)对比>
  • Python 变量
  • JVM虚拟机篇(二):深入剖析Java与元空间(MetaSpace)
  • 31信号和槽_信号和槽存在的意义(1)
  • bge-m3+deepseek-v2-16b+离线语音能力实现离线文档向量化问答语音版
  • AI绘画中的LoRa是什么?
  • Maven 远程仓库推送方法
  • Redis内存碎片详解!
  • samba共享配置
  • CodeCraft-22 and Codeforces Round 795 (Div. 2) D
  • 【网络安全论文】筑牢局域网安全防线:策略、技术与实战分析
  • Nginx介绍及使用
  • 美团滑块 分析
  • 【问题记录】C语言一个程序bug定位记录?(定义指针数组忘记[])
  • Pgvector的安装
  • 为什么AI需要向量数据库?
  • Redis数据结构之Hash
  • 如何通过共同训练 LLAMA3(大语言模型)与 GAT(图注意力网络)来实现检索增强生成(RAG),用于基于知识图谱信息回答问题
  • 【算法实践】算法面试常见问题——数组的波浪排序
  • 【VUE】RuoYi-Vue3项目结构的分析
  • 在QWidget中如何添加QAction
  • Unity:标签(tags)
  • 操作系统 4.5-文件使用磁盘的实现
  • 【奇点时刻】GPT4o新图像生成模型底层原理深度洞察报告(篇2)
  • 数据结构(JAVA)栈
  • Nacos 服务发现的核心模型有哪些?Service, Instance, Cluster 之间的关系是什么?
  • 基于Transformer框架实现微调后Qwen/DeepSeek模型的流式推理并封装成接口
  • 获取inode的完整路径包含挂载的路径
  • 蓝桥杯 完全平方数 刷题笔记