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分配的指地址

    评论

报告相同问题?

悬赏问题

  • ¥100 Jenkins自动化部署—悬赏100元
  • ¥15 关于#python#的问题:求帮写python代码
  • ¥20 MATLAB画图图形出现上下震荡的线条
  • ¥15 关于#windows#的问题:怎么用WIN 11系统的电脑 克隆WIN NT3.51-4.0系统的硬盘
  • ¥15 perl MISA分析p3_in脚本出错
  • ¥15 k8s部署jupyterlab,jupyterlab保存不了文件
  • ¥15 ubuntu虚拟机打包apk错误
  • ¥199 rust编程架构设计的方案 有偿
  • ¥15 回答4f系统的像差计算
  • ¥15 java如何提取出pdf里的文字?