Copyright(c) 2017,烟台大学计算机与控制工程学院
All rights reserved.
文件名称:text.cpp
作者:黄潇慧
完成日期:2017年10月26日
版本:vc6.0
问题描述:实现二叉树的先序、中序、后序遍历的递归算法,并对用”A(B(D,E(H(J,K(L,M(,N))))),C(F,G(,I)))”创建的二叉树进行测试。
输入描述:
输出描述:
代码实现:
调用下面这个二叉树的算法库
http://blog.youkuaiyun.com/sxhelijian/article/details/49250581
main.cpp
#include <stdio.h>
#include "d.h"
void PreOrder(BTNode *b) //先序遍历的递归算法
{
if (b!=NULL)
{
printf("%c ",b->data); //访问根节点
PreOrder(b->lchild); //递归访问左子树
PreOrder(b->rchild); //递归访问右子树
}
}
void InOrder(BTNode *b) //中序遍历的递归算法
{
if (b!=NULL)
{
InOrder(b->lchild); //递归访问左子树
printf("%c ",b->data); //访问根节点
InOrder(b->rchild); //递归访问右子树
}
}
void PostOrder(BTNode *b) //后序遍历的递归算法
{
if (b!=NULL)
{
PostOrder(b->lchild); //递归访问左子树
PostOrder(b->rchild); //递归访问右子树
printf("%c ",b->data); //访问根节点
}
}
int main()
{
BTNode *b;
CreateBTNode(b,"A(B(D,E(H(J,K(L,M(,N))))),C(F,G(,I)))");
printf("二叉树b:");
DispBTNode(b);
printf("\n");
printf("先序遍历序列:\n");
PreOrder(b);
printf("\n");
printf("中序遍历序列:\n");
InOrder(b);
printf("\n");
printf("后序遍历序列:\n");
PostOrder(b);
printf("\n");
DestroyBTNode(b);
return 0;
}
运行过程:
实践心得:
熟练掌握三种遍历方法
本文介绍了二叉树的先序、中序和后序遍历的递归算法,并通过具体的二叉树实例进行了测试验证。文章包含了完整的C语言代码实现。

被折叠的 条评论
为什么被折叠?



