c++ - 遍历二叉树出现

浏览:31日期:2023-03-15

问题描述

#include <stdio.h>#include <iostream>#include <string.h>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在此处segmentfaultprintf('%s',T->data); Traverse(T->rchild); }}int main(){ BITREE T; Create(T); Traverse(T);}

例子:4 2 1 # # 3 # # 5 # 6 # # (以先序输入)不知道出了什么问题。。。代码只是在教材上修改了data的部分。。

问题解答

回答1:

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

回答2:

T==NULL 应该改为 T=NULL

相关文章: