早教吧 育儿知识 作业答案 考试题库 百科 知识分享

二叉树的建立,二叉树的遍历。本实验要求实现以下功能:1.按前序次序建立一颗二叉树,以‘#’表示空。2.中序、后序遍历该二叉树,输出遍历序列。3.求出该二叉树的深度并输出,

题目详情
二叉树的建立,二叉树的遍历。
本实验要求实现以下功能:
1.按前序次序建立一颗二叉树,以‘#’表示空。
2.中序、后序遍历该二叉树,输出遍历序列。
3.求出该二叉树的深度并输出,或求出该二叉树的叶子数目并输出。
[测试数据]:
输入以下字符串,建立二叉树:ABC##DE#G##F###
输出中序遍历序列应为:CBEGDFA
输出后序遍历序列应为:CGEFDBA
输出二叉树的深度应为:5
输出二叉树的叶子数目应为:3
▼优质解答
答案和解析
#include "stdio.h"
//二叉树的练习
typedef struct BiTNode
{
char data; /*结点的数据域*/
struct BiTNode *lchild , *rchild; /*指向左孩子和右孩子*/
} BiTNode , *BiTree;
/*创建一棵二叉树*/
CreatBiTree(BiTree *T)
{
char c;

c = getch();
printf("get = %c\n",c);
if(c == ' ')
*T = NULL;
else
{
*T = (BiTNode * )malloc(sizeof(BiTNode)); /*创建根结点*/
(*T)->data = c; /*向根结点中输入数据*/
CreatBiTree(&((*T)->lchild)); /*递归地创建左子树*/
CreatBiTree(&((*T)->rchild)); /*递归地创建右子树*/
}
}
/*访问二叉树结点,输出包含D字符结点位于二叉树中的层数*/
visit(char c,int level)
{
if(c == 'D')
printf("%c is at %d lever of BiTree\n",c,level);
}
/*遍历二叉树*/
//先序
PreOrderTraverse(BiTree T,int level)
{
if(T)
{ /*递归结束条件,T为空*/
printf("node: %c, level: %d\n",T->data,level);
//visit(T->data,level); /*访问根结点*/
PreOrderTraverse(T->lchild,level+1); /*先序遍历T的左子树*/
PreOrderTraverse(T->rchild,level+1); /*先序遍历T的右子数*/
}
}
//中序
InOrderTraverse(BiTree T,int level)
{
if(T)
{ /*递归结束条件,T为空*/
InOrderTraverse(T->lchild,level+1); /*先序遍历T的左子树*/
printf("node: %c, level: %d\n",T->data,level);
InOrderTraverse(T->rchild,level+1); /*先序遍历T的右子数*/
}
}
//后序
PostOrderTraverse(BiTree T,int level)
{
if(T)
{ /*递归结束条件,T为空*/
PostOrderTraverse(T->lchild,level+1); /*先序遍历T的左子树*/
PostOrderTraverse(T->rchild,level+1); /*先序遍历T的右子数*/
printf("node: %c, level: %d\n",T->data,level);
}
}
//统计二叉树叶子节点数
int CountLeaf(BiTree T)
{
static int count = 0;
if (T)
{
count = CountLeaf(T->lchild);
if ((T->lchild == NULL) && (T->rchild == NULL))
{
count ++;
}
count = CountLeaf(T->rchild);
}
return count;
}
//求二叉树的深度
int TreeDepth(BiTree T)
{
static int count = 0;

if (T)
{
count++;
count = TreeDepth(T->lchild);
count = TreeDepth(T->rchild);
}
return count;
}
main()
{
int level = 1;
int Node_num = 0,Depth_num = 0;
BiTree T = NULL; /*最开始T指向空*/

CreatBiTree(&T); //创建二叉树,先画出树形图,根据图进行输入创建
printf("\n先序遍历:\n");
PreOrderTraverse(T,level); //遍历二叉树,找到包含D字符结点位于二叉树中的层数
printf("\n中序遍历:\n");
InOrderTraverse(T,level); //遍历二叉树,找到包含D字符结点位于二叉树中的层数
printf("\n后序遍历:\n");
PostOrderTraverse(T,level); //遍历二叉树,找到包含D字符结点位于二叉树中的层数

Node_num = CountLeaf(T);
Depth_num = TreeDepth(T);
printf("\nNode_num = %d, Depth_num = %d\n",Node_num,Depth_num);
}
看了 二叉树的建立,二叉树的遍历。...的网友还看了以下:

如图所示,把振动的音叉移近一个用细绳吊着的很轻的塑料球,音叉并没有碰到球,球发生了运动,发生这种现  2020-05-13 …

小号叉叉符号怎么打如图,有知道的说下.是小叉叉哦.并且这个不是字符,是个字,这个游戏的用户昵称是不  2020-05-17 …

高中物理:2个完全相同的音叉,共鸣箱相对放置,敲击音叉1,并迅速握住,使1停止发声,问音叉2会发声  2020-05-21 …

如图,把振动的音叉移近一个用细绳吊着的很轻的塑料球,音叉并没有碰到球,球发生了运动,发生这种现象的  2020-06-03 …

C语言,编程序。1.把两个整数a和b的较大者存入变量max,并输出。2.输入一个实数给变量x,求其  2020-06-09 …

已知一棵二叉树的中序序列和后序序列分别为c,b,a,e,d,h,g,j,i,f和c,b,e,h,j  2020-06-12 …

标志是一个倒梯形,上宽下窄,里面一个叉还有一条横线,就像是一个盆里面有水,还有一个叉,还有一个标志  2020-07-08 …

如图2-14所示,敲击左边的声叉,右边完塑料小球全相同的声叉野会发声叉声叉声,并把旁近的泡沫图2-  2020-07-08 …

一个字--上下结构,上面一个叉叉,下面一个叉叉,这个字念什么一个字,上面一个叉叉,下面一个叉叉,这  2020-07-08 …

如图所示,用力敲响音叉,并用悬挂着的塑料球接触发声的叉股,我们看到的现象是,此现象说明,塑料球的作  2020-07-14 …