J'ai une affectation, où je suis censé écrire des fonctions pour insérer/supprimer des structures d'arbre, mais j'ai du mal à exécuter le programme correctement. Voici le code squelette:C programme pour insérer/supprimer des nœuds, avoir du mal à fonctionner
typedef struct tree tree;
#define MAXWORD 26
struct tree{
struct tree *b4;
struct tree *after;
char word[MAXWORD];
};
void Insert(char *);
void Delete(char *);
#ifndef MAIN
extern tree *root;
#endif
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#define MAIN 1
#include "tree.h"
void printtree();
tree *root=NULL;
main(int argc, char **argv)
{
tree *node;
char buf[MAXWORD];
extern tree *root;
tree *p;
while((scanf("%s",buf))>0)
Insert(buf);
while(argc-->1)
Delete(argv[argc]);
printf("Print binary tree in order\n");
if(root!=NULL)
printtree(root);
}
void printtree(tree *root){
if(root->b4!=NULL)
printtree(root->b4);
printf("Node is %s \n",root->word);
if (root->after!=NULL)
printtree(root->after);
}
et la sortie devrait être quelque chose comme:
projet>: cat - | ./bintree abc xyz 2>/dev/null
abc
qwe
asd
zxc
qwe
impression d'arbre binaire pour
Node est asd
Node est un projet qwe
nœud est zxc
>:
Pour une raison quelconque, mais après avoir écrit ma fonction d'insertion et l'exécution du programme, je vais avoir du mal à courir le « arbre d'impression commander "section du programme avec succès sans qu'il s'agisse d'une boucle sans fin, demandant des commentaires. Des idées?
S'il vous plaît fixer votre empreinte. – ThingyWotsit