首页 诗词 字典 板报 句子 名言 友答 励志 学校 网站地图
当前位置: 首页 > 教程频道 > 开发语言 > C语言 >

二叉树有关问题

2012-03-08 
二叉树问题以下是二叉树的建立和遍历,可是结果不对:输入ABC##DE#G##F###(#表示空格)输出的只有:ABC,望高手

二叉树问题
以下是二叉树的建立和遍历,可是结果不对:输入ABC##DE#G##F###(#表示空格)输出的只有:ABC,望高手指点!~

#include   <stdio.h>
#include   <stdlib.h>
typedef   struct   BiTNode
{
char   data;
struct   BiTNode   *lchild,*rchild;
}BiTree;

BiTree   *CreateBiTree()
{  
BiTree   *T;
char   ch;
scanf( "%c ",&ch);
if(ch== '   ')
{
T=NULL;
}
else
{
if(!(T=(BiTree*)malloc(sizeof(BiTree))))
{
printf( "\nError!~ ");
return   T;
}
T-> data=ch;
T-> lchild=CreateBiTree();
T-> rchild=CreateBiTree();
}
return   T;
}


void   PreOrderTraverse(BiTree   *T)
{
if(T!=NULL)
{
printf( "%c ",T-> data);
}
PreOrderTraverse(T-> lchild);
PreOrderTraverse(T-> rchild);
}


int   main()
{
BiTree   *T;
T=(BiTree*)malloc(sizeof(BiTree));
T=CreateBiTree();
PreOrderTraverse(T);
return   0;
}


[解决办法]
不知道这样是否可以啊;
#include <stdio.h>
#include <stdlib.h>
typedef struct BiTNode
{
char data;
struct BiTNode *lchild,*rchild;
}BiTree;

BiTree *CreateBiTree()
{
BiTree *T;
char ch;
scanf( "%c ",&ch);
if(ch== ' ')
{
T=NULL;
}
else
{
if(!(T=(BiTree*)malloc(sizeof(BiTree))))
{
printf( "\nError!~ ");
return T;
}
T-> data=ch;
T-> lchild=CreateBiTree();
T-> rchild=CreateBiTree();
}
return T;
}


void PreOrderTraverse(BiTree *T)
{
if(T!=NULL)
{
printf( "%c ",T-> data);

PreOrderTraverse(T-> lchild);
PreOrderTraverse(T-> rchild);
}
}


int main()
{
BiTree *T;
T=(BiTree*)malloc(sizeof(BiTree));
T=CreateBiTree();
PreOrderTraverse(T);
return 0;
}

热点排行