二叉树的链式建立和返回叶子节点数,编译没问题但运行有问题??
data:image/s3,"s3://crabby-images/49bef/49befe47321efd6e9a465164befa1ac495071b22" alt=""
#include<stdio.h> #include<malloc.h> struct BTnode { char data; struct BTnode *Lchild,*Rchild; }; void CreateBTree(struct BTnode *B) { char ch=getchar(); if(ch=='a') { B=NULL; } else { B=(struct BTnode *)malloc(sizeof(struct BTnode)); B->data=ch; CreateBTree(B->Lchild); CreateBTree(B->Rchild); } } int Countleaf(struct BTnode *B) { if(B==NULL) return 0; if(B->Lchild==NULL&&B->Rchild==NULL) return 1; return(Countleaf(B->Lchild)+Countleaf(B->Rchild)); } void main() { struct BTnode B; CreateBTree(&B); Countleaf(&B); }