二叉树三种遍历方式——前序、中序、后序(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操作。
相关推荐
小陈工1 小时前
Python Web开发入门(十七):Vue.js与Python后端集成——让前后端真正“握手言和“
开发语言·前端·javascript·数据库·vue.js·人工智能·python
海清河晏1111 小时前
数据结构 | 单循环链表
数据结构·算法·链表
H Journey1 小时前
C++之 CMake、CMakeLists.txt、Makefile
开发语言·c++·makefile·cmake
wuweijianlove5 小时前
算法性能的渐近与非渐近行为对比的技术4
算法
研究点啥好呢5 小时前
Github热门项目推荐 | 创建你的像素风格!
c++·python·node.js·github·开源软件
_dindong5 小时前
cf1091div2 C.Grid Covering(数论)
c++·算法
AI成长日志5 小时前
【Agentic RL】1.1 什么是Agentic RL:从传统RL到智能体学习
人工智能·学习·算法
lly2024065 小时前
C 标准库 - `<stdio.h>`
开发语言
沫璃染墨5 小时前
C++ string 从入门到精通:构造、迭代器、容量接口全解析
c语言·开发语言·c++
jwn9995 小时前
Laravel6.x核心特性全解析
开发语言·php·laravel