資料結構集中實踐 哈夫曼樹實驗報告

2022-09-16 02:57:09 字數 1574 閱讀 8439

二、實驗內容

1.根據給出的字元以及這些字元的使用頻率構建哈夫曼樹。

2.根據哈夫曼樹對字元進行哈夫曼編碼,並儲存這些編碼。

三、實驗原理、方法和手段

試構造出問題模型,並程式設計實現這一問題的求解。根據實驗內容程式設計,上機除錯、得出正確的執行程式;編譯執行程式,觀察運**況和輸出結果。

六、實驗步驟

1. 建立哈夫曼樹的儲存結構和哈夫曼編碼的儲存結構。

2. 建立哈夫曼樹的函式;

3. 哈夫曼編碼的函式;

4.哈夫曼編碼的解碼函式

5. 設計測試用例進行測試。

七、實驗報告

記錄資料結構與演算法設計的過程及實驗步驟、上機過程中遇到的困難及解決辦法、遺留的問題、托福考位

意見和建議等。格式見實驗報告模板。 測試資料及測試結果請在上交的資料中寫明。

#include #include #define n 50

#define m 2*n-1

const int inf=1e9+7;

typedef struct//哈夫曼樹的儲存結構

htnode;

typedef struct//存放哈夫曼碼儲存結構

hcode;

void createht(htnode ht,int n0) //建立哈夫曼樹的函式

else if(ht[k].weight}

ht[i].weight=ht[lnode].weight+ht[rnode].weight;

ht[i].lchild=lnode;

ht[i].rchild=rnode;

ht[lnode].parent=i;

ht[rnode].parent=i; }}

void createhcode(htnode ht,hcode hcd,int n0) //構造哈夫曼樹編碼

hc.start++;

hcd[i]=hc; }}

void disphcode(htnode ht,hcode hcd,int n0) }

void decode(htnode ht,char code) //解碼

int t;

int a1=0,a2=0;

for(int i=0;ia2=i;

if(t==-1||ht[t].lchild!=-1&&ht[t].rchild!=-1)

else

} printf("\n");

}int main()

; double fnum=;

char code[40];

htnode ht[m];//存哈夫曼樹

hcode hcd[n];//存哈夫曼編碼

for (i=0;icreateht(ht,n);

createhcode(ht,hcd,n);

disphcode(ht,hcd,n);

printf("\n");

printf(" 請輸入編碼:");

scanf("%s",code);

decode(ht,code);

return 1;

}

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

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

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

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

資料結構 哈夫曼樹

哈夫曼樹是二叉樹的一種。被稱為最優二叉樹。實際應用中最重要的是帶權路徑長度。樹的路徑長度 樹中每個結點的路徑長度之和。權 附加在樹節點上,表示出現的概率。樹的帶權路徑長度 所有葉子結點帶權長度之和。看例項 的結點路徑長度 從d到 a的路徑,共走了兩條邊,所以為2。樹中的葉子結點有 d,e和 f。結點...