C語言哈夫曼編碼實驗報告_第1頁
C語言哈夫曼編碼實驗報告_第2頁
C語言哈夫曼編碼實驗報告_第3頁
C語言哈夫曼編碼實驗報告_第4頁
C語言哈夫曼編碼實驗報告_第5頁
已閱讀5頁,還剩6頁未讀, 繼續(xù)免費(fèi)閱讀

下載本文檔

版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報或認(rèn)領(lǐng)

文檔簡介

1、 福建工程學(xué)院課程設(shè)計課程:數(shù)據(jù)結(jié)構(gòu)題目哈夫曼編碼和譯碼專業(yè):信息管理信息系統(tǒng)班級:1002班座號:15號名:2011年6月27日實驗題目:哈夫曼編碼和譯碼一、要解決的問題利用哈夫曼編碼進(jìn)行信息通信可以大大提高信道利用率,縮短信息傳輸時間,降低傳輸成本。但是,這要求在發(fā)送端通過一個編碼系統(tǒng)對待傳數(shù)據(jù)預(yù)先編碼,在接收端將傳來的數(shù)據(jù)進(jìn)行譯碼(復(fù)原)。對于雙工信道(即可以雙向傳輸信息的信道),每端都需要一個完整的編/譯碼系統(tǒng)。二、算法基本思想描述:根據(jù)給定的字符和其中每個字符的頻度,構(gòu)造哈夫饅樹,并輸出字符集中每個字符的哈夫曼編碼.將給定的字符串根據(jù)其哈夫曼編碼進(jìn)行編碼,并進(jìn)行相應(yīng)的譯碼.三、設(shè)計數(shù)

2、據(jù)結(jié)構(gòu)的設(shè)計哈夫曼樹的表示設(shè)計哈夫曼樹的結(jié)構(gòu)體(htnode),其中包含權(quán)重、左右孩子、父母和要編碼的字符。用這個結(jié)構(gòu)體(htnode)定義個哈夫曼數(shù)組(hfmt)。迷宮定義如下:typedefstructintweight;intlchild;intrchild;intparent;charkey;htnode;typedefhtnodehfmtMAXLEN;對原始字符進(jìn)行編碼初始化哈夫曼樹(inithfmt)。從終端讀入字符集大小n,以及n個字符和n個權(quán)值,建立哈夫曼樹。并顯示出每個字符的編碼。voidinithfmt(hfmtt)對結(jié)構(gòu)體進(jìn)行初始化voidinputweight(hfmt

3、t)輸入函數(shù)voidselectmin(hfmtt,inti,int*p1,int*p2)選中兩個權(quán)值最小的函數(shù)voidcreathfmt(hfmtt)創(chuàng)建哈夫曼樹的函數(shù)voidphfmnode(hfmtt)對字符進(jìn)行初始編碼對用戶輸入的字符進(jìn)行編碼voidencoding(hfmtt)/對用戶輸入的電文進(jìn)行編碼charr1000;/用來存儲輸入的字符串inti,j;printf(nn請輸入需要編碼的字符:);gets(r);printf(編碼結(jié)果為:);for(j=0;rj!=0;j+)for(i=0;in;i+)if(rj=ti.key)hfmtpath(t,i,j);printf(n);

4、對用戶輸入的字符進(jìn)行編碼voiddecoding(hfmtt)/對用戶輸入的密文進(jìn)行譯碼charr100;inti,j,len;j=2*n-2;/j初始從樹的根節(jié)點(diǎn)開始printf(nn請輸入需要譯碼的字符串:);gets(r);len=strlen(r);printf(譯碼的結(jié)果是:);for(i=0;ilen;i+)if(ri=0)j=tj.lchild;if(tj.lchild=-1)printf(%c,tj.key);j=2*n-2;elseif(ri=1)j=tj.rchild;if(tj.rchild=-1)printf(%c,tj.key);j=2*n-2;printf(nn);

5、四、源程序清單:#include#include#include#defineMAXLEN100typedefstructintweight;intlchild;intrchild;intparent;charkey;htnode;typedefhtnodehfmtMAXLEN;intn;voidinithfmt(hfmtt)/對結(jié)構(gòu)體進(jìn)行初始化inti;printf(n);printf(n);printf(*輸入?yún)^(qū)*n);printf(n請輸入n二);scanf(%d,&n);getchar();for(i=0;i2*n-l;i+)/對結(jié)構(gòu)體進(jìn)行初始化ti.weight=0;ti.lchil

6、d=-1;ti.rchild=-1;ti.parent=-1;printf(n);voidinputweight(hfmtt)/輸入函數(shù)intw;/w表示權(quán)值inti;chark;/k表示獲取的字符for(i=0;itj.weight)min1=tj.weight;*p1=j;for(j=0;j二i;j+)/選擇次小權(quán)值字符的下標(biāo)還回if(tj.parent=-1)if(min2tj.weight&j!=(*pl)/主意j!=(*pl)min2=tj.weight;*p2=j;voidcreathfmt(hfmtt)/創(chuàng)建哈夫曼樹的函數(shù)inti,p1,p2;inithfmt(t);inputw

7、eight(t);for(i=n;i2*n-1;i+)selectmin(t,i-1,&p1,&p2);tp1.parent=i;tp2.parent=i;ti.lchild=p1;ti.rchild=p2;ti.weight=tp1.weight+tp2.weight;voidprinthfmt(hfmtt)/打印哈夫曼樹inti;printf(n);printf(*哈夫曼編數(shù)結(jié)木勾:*n)printf(tt權(quán)重t父母t左孩子t右孩子t字符t);for(i=0;i2*n-1;i+)printf(n);printf(tt%dt%dt%dt%dt%c,ti.weight,ti.parent,ti

8、.lchild,ti.rchild,ti.key);printf(nn)7printf(nn);voidhfmtpath(hfmtt,inti,intj)/編碼的重要哈夫曼樹路徑遞歸算法inta,b;a=i;b=j=ti.parent;if(tj.parent!=-1)i=j;hfmtpath(t,i,j);if(tb.lchild=a)printf(0);elseprintf(1);voidphfmnode(hfmtt)/對字符進(jìn)行初始編碼inti,j,a;printf(nn)printf(* *);for(i=0;in;i+)j=0;printf(n);printf(tt%ct,ti.ke

9、y,ti.weight);hfmtpath(t,i,j);printf(nvoidencoding(hfmtt)/對用戶輸入的電文進(jìn)行編碼charr1000;/用來存儲輸入的字符串inti,j;printf(nn請輸入需要編碼的字符:);gets(r);printf(編碼結(jié)果為:);for(j=0;rj!=0;j+)for(i=0;in;i+)if(rj=ti.key)hfmtpath(t,i,j);printf(n);voiddecoding(hfmtt)/對用戶輸入的密文進(jìn)行譯碼charr100;inti,j,len;j=2*n-2;/j初始從樹的根節(jié)點(diǎn)開始printf(nn請輸入需要譯碼

10、的字符串:);gets(r);len=strlen(r);printf(譯碼的結(jié)果是:);for(i=0;ilen;i+)if(ri=0)j=tj.lchild;if(tj.lchild=-1)printf(%c,tj.key);j=2*n-2;elseif(ri=1)j=tj.rchild;if(tj.rchild=-1)printf(%c,tj.key);j=2*n-2;printf(nn);intmain()inti,j;hfmtht;charflag;printf(|n);printf(信管1002-林左權(quán)-15號|n);printf(|*|n);printf(|哈夫曼編碼課程設(shè)計|n

11、);printf(|*|n);printf(“I設(shè)計完成時間:2011/6/27|n);printf(|n);creathfmt(ht);printhfmt(ht);phfmnode(ht);printf(nprintf(*編碼&譯碼&退出*);printf(n【1】編碼t【2】t譯碼t【0】退出);printf(n您的選擇:);flag=getchar();getchar();while(flag!=0)if(flag=1)encoding(ht);elseif(flag=2)decoding(ht);elseprintf(您的輸入有誤,請重新輸入。n);printf(n*編碼&譯碼&退出*)printf(n【1】編碼t【2】t譯碼t【0】退出“);printf(n您的選擇:“);flag=getchar();getchar();printf(nnn);printf(“*歡迎使用林左權(quán)的哈夫曼編碼系統(tǒng)*n);printf(“system(pause);五、測試數(shù)據(jù)及測試結(jié)果:例如:M言管1002林左15號:I耳MM耳MMMM耳MM耳MM耳MM耳MMKMI!哈夫曼編碼課程設(shè)計!;設(shè)計完咸時間=2011/6/27!MM耳MM耳耳MM耳MM耳耳M車甬j/,區(qū)耳耳MM耳MXKMMKMMKXKM請

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
  • 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論