c++ – Es erscheint ein durchlaufender Binärbaum
怪我咯
怪我咯 2017-06-17 09:16:08
0
2
671
#include  #include  #include  typedef struct node{ char data[4]; //结点数据是字符串 node *lchild,*rchild; }NODE,*BITREE; void Create(BITREE &T){ char str[4]; scanf("%s",str); if(str[0]=='#'){ T==NULL; } else{ T=new NODE; strcpy(T->data,str); Create(T->lchild); Create(T->rchild); } } void Traverse(BITREE T){ if(T){ Traverse(T->lchild); //!!!debug在此处segmentfault printf("%s",T->data); Traverse(T->rchild); } } int main(){ BITREE T; Create(T); Traverse(T); }

Beispiel: 4 2 1 # # 3 # # 5 # 6 # # (in der Reihenfolge eingeben)
Ich weiß nicht, was schief gelaufen ist. . . Der Code ändert nur den Datenteil des Lehrbuchs. .

怪我咯
怪我咯

走同样的路,发现不同的人生

Antworte allen (2)
滿天的星座

lchildrchild都是指针,他们所指向的应该是一个node结构体,但是在Create里并没有看到对lchildrchild所指向的结构体进行初始化。

    小葫芦

    T==NULL 应该改为 T=NULL

      Neueste Downloads
      Mehr>
      Web-Effekte
      Quellcode der Website
      Website-Materialien
      Frontend-Vorlage
      Über uns Haftungsausschluss Sitemap
      Chinesische PHP-Website:Online-PHP-Schulung für das Gemeinwohl,Helfen Sie PHP-Lernenden, sich schnell weiterzuentwickeln!