【发布时间】:2013-05-19 13:08:33
【问题描述】:
我想创建一个二叉树并通过前序遍历来遍历它,并且我使用递归方法。这些代码可以编译但不能正常运行,我发现可能无法完成CreateBitree()函数,但不知道问题出在哪里。
#include <stdio.h>
#include <malloc.h>
typedef struct BiNode{
int data;
struct BiNode *lchild;
struct BiNode *rchild; //left and right child pointer
}BiNode;
int CreateBiTree(BiNode *T);
int TraverseBiTree(BiNode *T);
int main() {
BiNode *t;
CreateBiTree(t);
TraverseBiTree(t);
return 0;
}
int CreateBiTree(BiNode *T) { //create a binary tree by preorder traversal
char tmp;
scanf("%c", &tmp);
if(tmp == ' ')
T = NULL;
else {
T = (BiNode *)malloc(sizeof(BiNode));
T -> data = tmp;
CreateBiTree(T -> lchild);
CreateBiTree(T -> rchild);
}
return 1;
}
int TraverseBiTree(BiNode *T) { //traverse a binary tree by preorder traversal
if(T != NULL) {
printf("%c\n", T -> data);
TraverseBiTree(T -> lchild);
TraverseBiTree(T -> rchild);
}
return 1;
}
例如,当我输入“ABC##DE#G##F###”(“#”表示空格)之类的预购序列,然后它仍然让我输入时,我认为TraverseBiTree()函数没有'没有被处决。
【问题讨论】:
-
当你说它不起作用时......你的意思是什么?放错了吗?分段故障?还有什么?
-
您通过 value 将指针值传递给 CreateBiTree。调用方永远不会得到更新的指针(包括它自己)。