二叉树三种遍历方式——前序、中序、后序(C++)

以下是使用C++实现的二叉树前序、中序和后序遍历的递归方法示例:

cpp 复制代码
#include <iostream>

using namespace std;

// 二叉树节点结构体
struct TreeNode {
    int val;
    TreeNode* left;
    TreeNode* right;
    TreeNode(int x) : val(x), left(nullptr), right(nullptr) {}
};

// 前序遍历
void preOrder(TreeNode* root) {
    if (root == nullptr) return;
    cout << root->val << " ";
    preOrder(root->left);
    preOrder(root->right);
}

// 中序遍历
void inOrder(TreeNode* root) {
    if (root == nullptr) return;
    inOrder(root->left);
    cout << root->val << " ";
    inOrder(root->right);
}

// 后序遍历
void postOrder(TreeNode* root) {
    if (root == nullptr) return;
    postOrder(root->left);
    postOrder(root->right);
    cout << root->val << " ";
}

int main() {
    // 构建示例二叉树
    //       1
    //     /   \
    //    2     3
    //   / \   /
    //  4   5 6
    TreeNode* root = new TreeNode(1);
    root->left = new TreeNode(2);
    root->right = new TreeNode(3);
    root->left->left = new TreeNode(4);
    root->left->right = new TreeNode(5);
    root->right->left = new TreeNode(6);

    // 输出遍历结果
    cout << "前序遍历: ";
    preOrder(root);
    cout << endl;

    cout << "中序遍历: ";
    inOrder(root);
    cout << endl;

    cout << "后序遍历: ";
    postOrder(root);
    cout << endl;

    // 释放内存(简单示例中省略,实际使用时应注意内存管理)
    return 0;
}

输出结果:

复制代码
前序遍历: 1 2 4 5 3 6 
中序遍历: 4 2 5 1 6 3 
后序遍历: 4 5 2 6 3 1 

代码说明:

  1. 二叉树结构定义 :使用TreeNode结构体表示二叉树的节点,包含值val和左右子节点指针。
  2. 递归遍历函数
    • 前序遍历:先访问根节点,然后递归遍历左子树,最后递归遍历右子树。
    • 中序遍历:先递归遍历左子树,然后访问根节点,最后递归遍历右子树。
    • 后序遍历:先递归遍历左子树,然后递归遍历右子树,最后访问根节点。
  3. 示例二叉树的构建:手动创建了一个包含6个节点的二叉树,用于演示遍历结果。
  4. 内存管理 :示例中未显式释放内存,实际应用中应根据需要添加delete操作。
相关推荐
古城小栈几秒前
Rust 网络请求库:reqwest
开发语言·网络·rust
hqwest19 分钟前
码上通QT实战12--监控页面04-绘制6个灯珠及开关
开发语言·qt·qpainter·qt事件·stackedwidget
i橡皮擦25 分钟前
TheIsle恐龙岛读取游戏基址做插件(C#语言)
开发语言·游戏·c#·恐龙岛·theisle
bing.shao1 小时前
golang 做AI任务执行
开发语言·人工智能·golang
清木铎1 小时前
leetcode_day4_筑基期_《绝境求生》
算法
清木铎1 小时前
leetcode_day10_筑基期_《绝境求生》
算法
j_jiajia1 小时前
(一)人工智能算法之监督学习——KNN
人工智能·学习·算法
源代码•宸2 小时前
Golang语法进阶(协程池、反射)
开发语言·经验分享·后端·算法·golang·反射·协程池
basketball6162 小时前
python 的对象序列化
开发语言·python
fie88893 小时前
钢结构件制造车间生产调度实例:MATLAB实现(基于遗传算法)
开发语言·matlab·制造