Problem Description
已知一个按先序序列输入的字符序列,如abc,,de,g,,f,,,(其中逗号表示空节点)。请建立二叉树并按中序和后序方式遍历二叉树,最后求出叶子节点个数和二叉树深度。
Input
输入一个长度小于50个字符的字符串。
Output
输出共有4行:
第1行输出中序遍历序列;
第2行输出后序遍历序列;
第3行输出叶子节点个数;
第4行输出二叉树深度。
Example Input
abc,,de,g,,f,,,
Example Output
cbegdfa
cgefdba
3
5
代码
#include <stdio.h>
char str[51];
int i=0,cont=0;
typedef struct BiNode{
int data;
struct BiNode *lchild,*rchild;
}BiNode,*BiTree;
BiTree CreatBiTree(BiTree T)
{
char temp=str[i++];
if(temp==',')
T=NULL;
else{
T=(BiTree)malloc(sizeof(BiNode));
T->data=temp;
T->lchild=CreatBiTree(T->lchild);
T->rchild=CreatBiTree(T->rchild);
}
return T;
}
void InOrderTraverse(BiTree T)
{
if(T)
{
if(T->lchild==NULL&&T->rchild==NULL)
cont++;
InOrderTraverse(T->lchild);
printf("%c",T->data);
InOrderTraverse(T->rchild);
}
}
int depth(BiTree T)
{
int dr,dl;//无需初始化,在递归出口中就能赋值
if(T==NULL)
return 0;
else
{
dl=depth(T->lchild);
dr=depth(T->rchild);
return dl>dr?dl+1:dr+1;
}
}
void PostOrderTraverse(BiTree T)
{
if(T)
{
PostOrderTraverse(T->lchild);
PostOrderTraverse(T->rchild);
printf("%c",T->data);
}
}
int main()
{
BiTree T=(BiTree)malloc(sizeof(BiNode));
scanf("%s",str);
T=CreatBiTree(T);
InOrderTraverse(T);
printf("\n");
PostOrderTraverse(T);
printf("\n");
printf("%d\n",cont);
printf("%d\n", depth(T));
return 0;
}