J'essaye d'implémenter le code adaptatif de huffman, mais en essayant de construire l'arbre j'obtiens une erreur de segmentation en exécutant le code à la ligne "currentNYT-> lchild = newNYT;" dans la fonction addnode().Faute de segmentation - Arbre Huffman adaptatif
Quelqu'un peut-il m'aider s'il vous plaît? Ce pourrait être quelque chose de simple dont je ne suis pas conscient. N'a pas utilisé C pendant un moment maintenant.
//variable and type declarations
struct treeElement {
unsigned long weight;
unsigned short id;
char chr;
struct treeElement *lchild, *rchild, *parent;
};
typedef struct treeElement node;
node *root, *currentNYT;
//functions
void initTree() {
root = NULL;
currentNYT = malloc(sizeof(node));
currentNYT = root;
} //initTree
void addNode(char newNodeChr) {
node *newNYT, *newExternal;
newNYT = malloc(sizeof(node));
newNYT->id=maxNodes-idCount; idCount++;
newNYT->chr='\0';
newNYT->weight=0;
newNYT->parent=currentNYT;
newNYT->lchild=newNYT->rchild=NULL;
newExternal = malloc(sizeof(node));
newExternal->id=maxNodes-idCount;
newExternal->chr=newNodeChr;
newExternal->weight=1;
newExternal->parent=currentNYT;
newExternal->lchild=newExternal->rchild=NULL;
currentNYT->lchild = newNYT;
currentNYT->rchild = newExternal;
currentNYT=newNYT;
} //addNode
Vous avez probablement intérêt à le republier comme nouvelle question. – caf