Как построить дерево Хаффмана из связанного списка в C? - PullRequest
0 голосов
/ 12 ноября 2018

У меня есть отсортированный связанный список, но я попробовал следующий код, чтобы создать дерево и распечатать его. Но я не могу получить вывод ..

NODE insertorder(NODE first,int pixel,int freq, NODE llink,NODE rlink)
{
    NODE temp=(NODE)malloc(sizeof(struct node));
    NODE cur,prev=NULL;
    temp->pix=pixel;
    temp->freq=freq;
    temp->llink=llink;
    temp->rlink=rlink;
    temp->link=NULL;
    if(first==NULL)
        return temp;
    cur=first;
    while(cur!=NULL&&freq>cur->freq)
    {
        prev=cur;
        cur=cur->link;
    }
    temp->link=cur;
    if(prev!=NULL)
        prev->link=temp;
    return first;
}
      void roots(NODE first)

        {
        NODE t1=first,t2=first->link;//taking first two elements in the list everytime

        if(t2!=NULL)
            createtree(t1,t2);
    }
     void createtree(NODE first,NODE nxt)
    {
       NODE temp=(NODE)malloc(sizeof(struct node));
       temp->pix=0;
       temp->freq=first->freq+nxt->freq;
       temp->llink=first;
       temp->rlink=nxt;
       temp->link=NULL;
       first=deletefirst(first);
       first=deletefirst(first);
       //inserting back the new sum of both elements into the same list
       first=insertorder(first, temp->pix, temp->freq, temp->llink, temp->rlink); 
       roots(first);//calling root back
    }
    printleaf(NODE first,int a[500],int current)
    {
        if(first->llink!=NULL)
        {
            a[current]=0;
            printleaf(first->llink,a,current+1);
        }
        if(first->rlink!=NULL)
        {
            a[current]=1;
            printleaf(first->rlink,a,current+1);
        }
        if(first->llink==NULL&&first->rlink==NULL)
            for(int i=0;a[i]!='\0';i++)
             printf("%d",a[i]);
    }    

Моя идея состоит в том, чтобы сохранить корень дерева в том же списке, который был там ранее, но когда я его выполнил, я не получил вывод.

1 Ответ

0 голосов
/ 13 ноября 2018

В списке ссылок, если есть ссылка и ссылка, это список двойной ссылки, и из кода не понятно, зачем нужна ссылка.При вставке следует использовать rlink и link, если в точке вставки как предыдущий узел, так и следующие узлы должны расположить свои rlink и link.

...