二叉树三种遍历方式——前序、中序、后序(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操作。
相关推荐
yzx99101336 分钟前
基于 Q-Learning 算法和 CNN 的强化学习实现方案
人工智能·算法·cnn
iCxhust38 分钟前
Prj10--8088单板机C语言8259测试(1)
c语言·开发语言
亮亮爱刷题39 分钟前
算法练习-回溯
算法
眼镜哥(with glasses)2 小时前
蓝桥杯 国赛2024python(b组)题目(1-3)
数据结构·算法·蓝桥杯
крон4 小时前
【Auto.js例程】华为备忘录导出到其他手机
开发语言·javascript·智能手机
zh_xuan4 小时前
c++ 单例模式
开发语言·c++·单例模式
老胖闲聊5 小时前
Python Copilot【代码辅助工具】 简介
开发语言·python·copilot
Blossom.1185 小时前
使用Python和Scikit-Learn实现机器学习模型调优
开发语言·人工智能·python·深度学习·目标检测·机器学习·scikit-learn
曹勖之5 小时前
基于ROS2,撰写python脚本,根据给定的舵-桨动力学模型实现动力学更新
开发语言·python·机器人·ros2
豆沙沙包?6 小时前
2025年- H77-Lc185--45.跳跃游戏II(贪心)--Java版
java·开发语言·游戏