输出利用二叉树存储的普通树的度
1000(ms)
10000(kb)
2572 / 5906
普通树可转换成相应的二叉树(该二叉树的根结点一定缺少右儿子),反之亦然。故而可以根据相应的转换方法去统计某一二叉树对应的普通树的度。普通树的度为其结点儿子数的最大值。相应的二叉树可利用二叉树的先序递归遍历算法创建。先序递归遍历建立二叉树的方法为:按照先序递归遍历的思想将对二叉树结点的抽象访问具体化为根据接收的数据决定是否产生该结点从而实现创建该二叉树的二叉链表存储结构。约定二叉树结点数据为单个大写英文字符。当接收的数据是字符"#"时表示该结点不需要创建,否则创建该结点。最后再统计该二叉树对应的森林中树的棵数。需要注意输入数据序列中的"#"字符的序列及个数关系,这会最终决定创建的二叉树的形态(序列里面允许无效字符但需要正确处理)。
输入
输入为接受键盘输入的由大写英文字符和"#"字符构成的一个字符串(用于创建对应的二叉树)。
输出
若表示的二叉树对应普通树,则该普通树的度;否则输出ERROR。
样例输入
AB#CD##E### ABC#### AB##C## ABCD###EF##G### A##B##
样例输出
3 1 ERROR 3 1
#include<stdio.h>
#include<malloc.h>
struct BTNode
{
char data;
struct BTNode *lchild;
struct BTNode *rchild;
struct BTNode *other[100];
int top;
};
void InstBTNode(struct BTNode *&p)//初始化top的值
{
p=(struct BTNode *)malloc(sizeof(struct BTNode));
p->top=-1;
}
void PreOrder(struct BTNode *&p)//先序遍历创建二叉树
{
char a;
scanf("%c",&a);
if(a=='#') p=NULL;
else
{
InstBTNode(p);
p->data=a;
PreOrder(p->lchild);
PreOrder(p->rchild);
}
}
void ConvertTree(struct BTNode *&p)//二叉树转换普通树
{
if(p!=NULL)
{
if(p->lchild!=NULL&&p->lchild->rchild!=NULL)//如果左孩子不为空,并且左孩子的右孩子不为空,则将左孩子的右孩子以及左孩子的右孩子的右孩子。。。。都储存在当前结点的other数组中
{
struct BTNode *t;
t=p->lchild->rchild;
while(t!=NULL)
{
p->other[++p->top]=t;
t=t->rchild;//继续查找下一个右孩子
}
}
ConvertTree(p->lchild);
ConvertTree(p->rchild);
}
}
int max=0;//初始化max,用它储存最大的度
void Num(struct BTNode *&p)
{
if(p!=NULL)
{
int sum=p->top+2;//top从0开始计算的,所以要加1,然后左孩子并未储存在other中,所以再加1,一共加2;
if(sum>max) max=sum;
Num(p->lchild);//递归该结点的左孩子
for(int i=0;i<=p->top;i++)//依次递归其他孩子
{
Num(p->other[i]);
}
}
}
int main()
{
struct BTNode *p;
PreOrder(p);
ConvertTree(p);
if(p->rchild!=NULL) printf("ERROR");//如果根结点有右孩子,则不是储存普通树的二叉树
else
{
Num(p);
printf("%d",max);
}
}