プログラムがツリーの最初の3文字だけを印刷している理由を理解できません。 助けてください。pre_order cでスタックを使用したトラバーサル
私はコンパイルchar stack[30];
は、他の問題があるかもしれません
struct node* stack[30];
で交換する必要があること。驚い
#include <stdio.h>
#include <malloc.h>
struct node
{
struct node *left;
char data;
struct node *right;
};
struct node *buildtree(int);
void pre_order(struct node*);
char a[]={'a','b','c','d','e','f','g','\0','\0','h','\0','\0','\0','\0','\0','\0','\0','\0','\0','\0','\0'};
int main()
{
struct node *root;
root = buildtree(0);
printf("pre order traversal:\n");
pre_order(root);
}
struct node *buildtree(int n)
{
struct node *temp = NULL;
if(a[n]!='\0')
{
temp=(struct node*)malloc(sizeof(struct node));
temp->left=buildtree(2*n+1);
temp->data=a[n];
temp->right=(2*n+2);
}
return temp;
}
void pre_order(struct node* root)
{
char stack[30];
struct node* ptr;
int top=1;
stack[1]=NULL;
ptr=root;
while(ptr!=NULL)
{
printf("%c",ptr->data);
if(ptr->right!=NULL)
{
top=top+1;
stack[top]=ptr->right;
}
if(ptr->left!=NULL)
ptr=ptr->left;
else
{
ptr=stack[top];
top=top-1;
}
}
}
ようこそstackoverflow。 1分ほどで[FAQ](http://stackoverflow.com/faq)をお読みください。質問を編集して(1)あなたが試したこと、(2)あなたが得ているエラーを追加してください。これが宿題であれば、 '宿題'タグを付け加えてください。 –