二叉树三种遍历方式——前序、中序、后序(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操作。
相关推荐
NEGl DRYN2 分钟前
Go基础之环境搭建
开发语言·后端·golang
AI木马人4 分钟前
20.人工智能实战:大模型项目如何从 Demo 走向生产?一套可落地的上线验收清单与工程治理方案
java·开发语言·人工智能
CandyU26 分钟前
Unity —— 反射
java·开发语言
初心未改HD7 分钟前
Go Modules:依赖管理的完全指南
开发语言·golang
楼田莉子7 分钟前
仿照Muduo的高并发服务器:EventLoop模块及与TimeWheel模块联调
java·开发语言
小雅痞9 分钟前
[Java][Leetcode middle] 3. 无重复字符的最长子串
java·开发语言·leetcode
qeen8714 分钟前
【算法笔记】简单贪心
c++·笔记·算法·贪心算法
逻辑驱动的ken20 分钟前
Java高频面试考点场景题21
java·开发语言·面试·职场和发展·求职招聘
ting945200025 分钟前
动手学深度学习(PyTorch版)深度详解(10): 优化算法 全解
人工智能·pytorch·深度学习·算法
rOuN STAT27 分钟前
Golang 构建学习
开发语言·学习·golang