二叉树三种遍历方式——前序、中序、后序(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操作。
相关推荐
Humbunklung6 分钟前
Rust枚举:让数据类型告别单调乏味
开发语言·后端·rust
Y1nhl10 分钟前
力扣_链表_python版本
开发语言·python·算法·leetcode·链表·职场和发展
OEC小胖胖23 分钟前
深入理解 Vue.js 响应式原理及其在 Web 前端开发中的应用
开发语言·前端·javascript·vue.js·web
qq_4017004125 分钟前
C语言中位运算以及获取低8位和高8位、高低位合并
c语言·开发语言·算法
CoovallyAIHub28 分钟前
YOLO模型优化全攻略:从“准”到“快”,全靠这些招!
深度学习·算法·计算机视觉
yanjiaweiya29 分钟前
云原生-集群管理
java·开发语言·云原生
闻缺陷则喜何志丹34 分钟前
【BFS】 P10864 [HBCPC2024] Genshin Impact Startup Forbidden II|普及+
c++·算法·宽度优先·洛谷
MicroTech20251 小时前
微算法科技(NASDAQ: MLGO)探索Grover量子搜索算法,利用量子叠加和干涉原理,实现在无序数据库中快速定位目标信息的效果。
数据库·科技·算法
qianbo_insist1 小时前
c++ python 共享内存
开发语言·c++·python