哈夫曼樹 (c語言)資料結構

2021-08-02 19:07:32 字數 1008 閱讀 9669

#include

#include

#include

#define n 100

typedef struct hfmshfmsnode;

typedef char *hfmscode;//動態分配陣列儲存哈夫曼編碼

//定義結構體型別

void select(hfmsnode *ht,int len ,int *s1, int *s2)

}//找到最小的乙個元素

for(i=1;i<=len;i++)

}//找到另乙個最小的元素

}hfmsnode *createhfms(int n)//構造哈夫曼樹

//為每個結點的p,l,r賦初值

for(i=1;i<=n;++i)

//為每個葉子結點賦初值

for(i=n+1;i<=m;i++)

return ht;

}void createhfmscode(hfmsnode *ht,hfmscode *hc, int n)//哈夫曼樹編碼

hc[i]=(char *)malloc((n-start)*sizeof(char));//為第乙個字元編碼分配空間

strcpy(hc[i], &cd[start]);//把求得的編碼的首位址從cd[start]複製到hc的當前行

}free(cd);

for(i=1;i<=n;i++)

}void  createhfmscode1(hfmsnode *ht,int m)//哈夫曼樹的解碼

else

i=ht[i].r;

if(ht[i].l==null)

j++;

}printf("\n");

}void menu()

int main()

printf("\n");

printf("no  weight  lchild  rchild\n");

for(i=1;i<2*n;i++)

return 0;

}//主函式

資料結構 哈夫曼樹 哈夫曼編碼

哈夫曼樹又稱最優樹 二叉樹 是一類帶權路徑最短的樹。構造這種樹的演算法最早是由哈夫曼 huffman 1952年提出,這種樹在資訊檢索中很有用。結點之間的路徑長度 從乙個結點到另乙個結點之間的分支數目。樹的路徑長度 從樹的根到樹中每乙個結點的路徑長度之和。結點的帶權路徑長度 從該結點到樹根之間的路徑...

哈夫曼編碼 哈夫曼樹 (資料結構)

哈夫曼編碼,又稱霍夫曼編碼,是一種編碼方式,哈夫曼編碼是可變字長編碼 vlc 的一種。huffman於1952年提出一種編碼方法,該方法完全依據字元出現概率來構造異字頭的平均長度最短的碼字,有時稱之為最佳編碼,一般就叫做huffman編碼 有時也稱為霍夫曼編碼 include include inc...

c 資料結構 哈夫曼樹

給定n個權值作為n的葉子結點,構造一棵二叉樹,若帶權路徑長度達到最小,稱這樣的二叉樹為最優二叉樹,也稱為哈夫曼樹 huffman tree 哈夫曼樹是帶權路徑長度最短的樹,權值較大的結點離根較近。如下 為老師所給 includeusing namespace std struct htnode 哈夫...