C语言数据结构(15)--二叉树的前序、中序、后序遍历

简介: 本文目录1. 背景2. 前序遍历3. 中序遍历4. 后序遍历5. 层序遍历6. 代码实现

1. 背景

在上一篇中,已经构造了一个二叉树,并且对其进行了遍历输出,实际上处于不同的需求,对二叉树节点的遍历顺序有不同的做法,本文就研究下最常用的二叉树的四种遍历算法。

先给一个标准的二叉树:

image.png

2. 前序遍历

前表示前面、先前的意思,序是顺序的意思,前序遍历是指根节点的访问顺序是在前面的,所以:


前序遍历:总是先访问根节点、然后访问左子树、然后访问右子树

1

所以对于上面的二叉树,前序遍历顺序为:A-B-D-E-C-F-G


3. 中序遍历

中表示的中间的意思,中序遍历是指根节点的访问顺序是在中间的,所以:


中序遍历:总是先访问左子树、然后访问根节点、然后访问右子树

1

所以对于上面的二叉树,中序遍历顺序为:D-B-E-A-F-C-G


4. 后序遍历

后是后面,后来的意思,后续遍历是指根节点的访问顺序是在后面的,所以:


后序遍历:总是先访问左子树、然后访问右子树、然后访问根节点

1

所以对于上面的二叉树,后序遍历顺序为:D-E-B-F-G-C-A


5. 层序遍历

这个好理解,按层次访问,所以:


层序遍历:自上层至下层,同层自左至右遍历

1

所以对于上面的二叉树,层序遍历顺序为:A-B-C-D-E-F-G


6. 代码实现

分析清楚了如何遍历的,代码实现也就水到渠成啦。

#include<stdio.h>
/*
* 二叉树的前序、中序、后序遍历演示DEMO
* 作者:熊猫大大
* 时间:2019-12-08
*/
#include <stdio.h>
typedef struct {
  char data;//数据区域(为了保存ABCD,直接用char当做数据域,便于和文章中的插图对应,稳!)
  struct BinaryTreeNode* left;//左子节点
  struct BinaryTreeNode* right;//右子节点
}BinaryTreeNode;
//为树的当前节点添加左子节点
int addLeftChild(BinaryTreeNode* curNode, char leftData)
{
  //分配新节点
  BinaryTreeNode* leftNode = (BinaryTreeNode*)malloc(sizeof(BinaryTreeNode));
  //为新节点挂载数据
  leftNode->data = leftData;
  //新节点暂时无子节点
  leftNode->left = NULL;
  leftNode->right = NULL;
  //将新节点挂到当前节点下
  curNode->left = leftNode;
  return 1;
}
//为树的当前节点添加右子节点
int addRightChild(BinaryTreeNode* curNode, char rightData)
{
  //分配新节点
  BinaryTreeNode* rightNode = (BinaryTreeNode*)malloc(sizeof(BinaryTreeNode));
  //为新节点挂载数据
  rightNode->data = rightData;
  //新节点暂时无子节点
  rightNode->left = NULL;
  rightNode->right = NULL;
  //将新节点挂到当前节点下
  curNode->right = rightNode;
  return 1;
}
// 前序遍历,根--左--右
void preOrder(BinaryTreeNode *node)
{
  if (node == NULL) {
    return;
  }
  printf("%c ", node->data);
  preOrder(node->left);
  preOrder(node->right);
}
// 中序遍历,左--根--右
void midOrder(BinaryTreeNode *node)
{
  if (node == NULL) {
    return;
  }
  midOrder(node->left);
  printf("%c ", node->data);
  midOrder(node->right);
}
// 后序遍历,左--根--右
void afterOrder(BinaryTreeNode *node)
{
  if (node == NULL) {
    return;
  }
  afterOrder(node->left);
  afterOrder(node->right);
  printf("%c ", node->data);
}
//----------------------------------------------------------------------------------------------------测试入口区域
int main()
{
  //设定根节点
  BinaryTreeNode root;
  //根节点A
  root.data = 'A';
  addLeftChild(&root, 'B');
  addRightChild(&root, 'C');
  //为B节点增加子节点
  addLeftChild(root.left, 'D');
  addRightChild(root.left, 'E');
  //为C节点增加子节点
  addLeftChild(root.right, 'F');
  addRightChild(root.right, 'G');
  printf("\n前序遍历:");
  preOrder(&root);
  printf("\n中序遍历:");
  midOrder(&root);
  printf("\n后序遍历:");
  afterOrder(&root);
  return 1;
}

PS:层序遍历有点复杂,后续实现。


相关文章
|
4天前
|
定位技术 C语言
c语言及数据结构实现简单贪吃蛇小游戏
c语言及数据结构实现简单贪吃蛇小游戏
|
22天前
|
搜索推荐 C语言
数据结构(C语言)之对归并排序的介绍与理解
归并排序是一种基于分治策略的排序算法,通过递归将数组不断分割为子数组,直到每个子数组仅剩一个元素,再逐步合并这些有序的子数组以得到最终的有序数组。递归版本中,每次分割区间为[left, mid]和[mid+1, right],确保每两个区间内数据有序后进行合并。非递归版本则通过逐步增加gap值(初始为1),先对单个元素排序,再逐步扩大到更大的区间进行合并,直至整个数组有序。归并排序的时间复杂度为O(n*logn),空间复杂度为O(n),且具有稳定性,适用于普通排序及大文件排序场景。
|
1月前
|
C++
【C++数据结构——树】二叉树的性质(头歌实践教学平台习题)【合集】
本文档介绍了如何根据二叉树的括号表示串创建二叉树,并计算其结点个数、叶子结点个数、某结点的层次和二叉树的宽度。主要内容包括: 1. **定义二叉树节点结构体**:定义了包含节点值、左子节点指针和右子节点指针的结构体。 2. **实现构建二叉树的函数**:通过解析括号表示串,递归地构建二叉树的各个节点及其子树。 3. **使用示例**:展示了如何调用 `buildTree` 函数构建二叉树并进行简单验证。 4. **计算二叉树属性**: - 计算二叉树节点个数。 - 计算二叉树叶子节点个数。 - 计算某节点的层次。 - 计算二叉树的宽度。 最后,提供了测试说明及通关代
46 10
|
1月前
|
Java C++
【C++数据结构——树】二叉树的基本运算(头歌实践教学平台习题)【合集】
本关任务:编写一个程序实现二叉树的基本运算。​ 相关知识 创建二叉树 销毁二叉树 查找结点 求二叉树的高度 输出二叉树 //二叉树节点结构体定义 structTreeNode{ intval; TreeNode*left; TreeNode*right; TreeNode(intx):val(x),left(NULL),right(NULL){} }; 创建二叉树 //创建二叉树函数(简单示例,手动构建) TreeNode*create
48 12
|
1月前
|
数据采集 存储 算法
【C++数据结构——图】图的遍历(头歌教学实验平台习题) 【合集】
本文介绍了图的遍历算法,包括深度优先遍历(DFS)和广度优先遍历(BFS)。深度优先遍历通过递归方式从起始节点深入探索图,适用于寻找路径、拓扑排序等场景;广度优先遍历则按层次逐层访问节点,适合无权图最短路径和网络爬虫等应用。文中提供了C++代码示例,演示了如何实现这两种遍历方法,并附有测试用例及结果,帮助读者理解和实践图的遍历算法。
44 0
|
1月前
|
存储 算法 测试技术
【C++数据结构——树】二叉树的遍历算法(头歌教学实验平台习题) 【合集】
本任务旨在实现二叉树的遍历,包括先序、中序、后序和层次遍历。首先介绍了二叉树的基本概念与结构定义,并通过C++代码示例展示了如何定义二叉树节点及构建二叉树。接着详细讲解了四种遍历方法的递归实现逻辑,以及层次遍历中队列的应用。最后提供了测试用例和预期输出,确保代码正确性。通过这些内容,帮助读者理解并掌握二叉树遍历的核心思想与实现技巧。
51 2
|
2月前
|
数据库
数据结构中二叉树,哈希表,顺序表,链表的比较补充
二叉搜索树,哈希表,顺序表,链表的特点的比较
数据结构中二叉树,哈希表,顺序表,链表的比较补充
|
3月前
|
算法 数据处理 C语言
C语言中的位运算技巧,涵盖基本概念、应用场景、实用技巧及示例代码,并讨论了位运算的性能优势及其与其他数据结构和算法的结合
本文深入解析了C语言中的位运算技巧,涵盖基本概念、应用场景、实用技巧及示例代码,并讨论了位运算的性能优势及其与其他数据结构和算法的结合,旨在帮助读者掌握这一高效的数据处理方法。
94 1
|
3月前
|
并行计算 算法 测试技术
C语言因高效灵活被广泛应用于软件开发。本文探讨了优化C语言程序性能的策略,涵盖算法优化、代码结构优化、内存管理优化、编译器优化、数据结构优化、并行计算优化及性能测试与分析七个方面
C语言因高效灵活被广泛应用于软件开发。本文探讨了优化C语言程序性能的策略,涵盖算法优化、代码结构优化、内存管理优化、编译器优化、数据结构优化、并行计算优化及性能测试与分析七个方面,旨在通过综合策略提升程序性能,满足实际需求。
99 1
|
3月前
|
存储 缓存 算法
在C语言中,数据结构是构建高效程序的基石。本文探讨了数组、链表、栈、队列、树和图等常见数据结构的特点、应用及实现方式
在C语言中,数据结构是构建高效程序的基石。本文探讨了数组、链表、栈、队列、树和图等常见数据结构的特点、应用及实现方式,强调了合理选择数据结构的重要性,并通过案例分析展示了其在实际项目中的应用,旨在帮助读者提升编程能力。
99 5

热门文章

最新文章