#include
#include<stdio.h>
#include<stdlib.h>
using namespace std;
typedef struct BiTNode
{
char data;
struct BiTNode *lchild,*rchild;
}BiTNode,*BinTree;
int InitList(BinTree &T)
{
T=(BinTree)malloc(sizeof(BiTNode));
T->data=NULL;
T->lchild=T->rchild=NULL;
}
void CreatBiTree(BinTree &T)
{
char ch;
ch=getchar();
if(ch=='#') T=NULL;
else
{
T->data=ch;
CreatBiTree((T)->lchild);
CreatBiTree((T)->rchild);
}
}
void preorder(BinTree &T)
{
if(T==NULL)
{
return;
}
else
{
cout << T->data;
preorder(T->lchild);
preorder(T->rchild);
}
}
void inorder(BinTree &T)
{
if(T==NULL)
{
return;
}
else
{
inorder(T->lchild);
cout << T->data;
inorder(T->rchild);
}
}
void posorder(BinTree &T)
{
if(T==NULL)
{
return;
}
else
{
posorder(T->lchild);
posorder(T->rchild);
cout << T->data;
}
}
int main()
{
BinTree T;
InitList(T);
CreatBiTree(T);
preorder(T);
cout << endl;
inorder(T);
cout << endl;
posorder(T);
cout << endl;
return 0;
}
帮我看看代码问题出在哪,修改错误