XwinterwinterwinterX 2016-01-02 09:12 采纳率: 50%
浏览 1470

C语言,请教关于创建二叉树的问题

void CreatBiTree(BiTree *T)
为什么是BiTree *T,而不是 BiTree T?

#include
typedef struct BiTNode {
char data;
struct BiTNode *lchild, *rchild;
}BiTNode, *BiTree;
void CreatBiTree(BiTree *T) {
char c;
scanf("%c", &c);
if (c == ' ')
*T = NULL;
else {
*T = (BiTNode *)malloc(sizeof(BiTNode));
(*T)->data = c;
CreatBiTree(&((*T)->lchild));
CreatBiTree(&((*T)->rchild));
}
}

  • 写回答

2条回答 默认 最新

  • c_flybird 2016-01-02 10:37
    关注

    因为你的创造函数里面用的是指针的功能啊,if(c==' ') *T=NULL; else *T = (BiTNode *)malloc(sizeof(BiTNode)); 只有指针才能接受malloc分配的指地址

    评论

报告相同问题?