统计利用二叉树存储的森林中树的棵数
1000(ms)
10000(kb)
2866 / 5350
普通树及其构成的森林均可转换成相应的二叉树,反之亦然。故而可以根据相应的转换方法去统计某一二叉树对应的森林中树的棵数。相应的二叉树可利用先序递归遍历算法创建。先序递归遍历建立二叉树的方法为:按照先序递归遍历的思想将对二叉树结点的抽象访问具体化为根据接收的数据决定是否产生该结点从而实现创建该二叉树的二叉链表存储结构。约定二叉树结点数据为单个大写英文字符。当接收的数据是字符"#"时表示该结点不需要创建,否则创建该结点。最后再统计该二叉树对应的森林中树的棵数。需要注意输入数据序列中的"#"字符和非"#"字符的序列及个数关系,这会最终决定创建的二叉树的形态(序列里面允许无效字符但需要正确处理)。
输入
输入为接受键盘输入的由大写英文字符和"#"字符构成的一个字符串(用于创建对应的二叉树)。
输出
输出该用例对应的二叉树表示的森林中树的棵数。
样例输入
A#B#CD### ABC#### AB##C## ABCD###EF##G##H## A##B##
样例输出
3 1 2 2 1
#include<stdio.h>
#include<malloc.h>
struct BTNode//二叉树结构体
{
char data;
struct BTNode *lchild;
struct BTNode *rchild;
};
void PreOrder(struct BTNode *&p)//先序遍历创建二叉树
{
char a;
scanf("%c",&a);
if(a=='#') p=NULL;
else
{
p=(struct BTNode *)malloc(sizeof(struct BTNode));
p->data=a;
PreOrder(p->lchild);
PreOrder(p->rchild);
}
}
int main()
{
struct BTNode *head,*p;
int sum=0;//初始化sum的值
PreOrder(head);
p=head;
while(p!=NULL)//统计右孩子以及右孩子的右孩子的个数 ,即为树的棵树
{
sum++;
p=p->rchild;
}
printf("%d",sum);
}