版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡(jiǎn)介
1、佛山科學(xué)技術(shù)學(xué)院實(shí) 驗(yàn) 報(bào) 告課程名稱 數(shù)據(jù)結(jié)構(gòu) 實(shí)驗(yàn)項(xiàng)目 用Huffman樹進(jìn)行編碼與解碼算法 專業(yè)班級(jí) 網(wǎng)絡(luò)工程2 姓 名 陳浩明 學(xué) 號(hào) 2010394223 指導(dǎo)教師 成 績(jī) 日 期 1、 實(shí)驗(yàn)?zāi)康?1、通過本實(shí)驗(yàn),熟悉二叉樹、Huffman樹的基本概念,掌握二叉樹的存儲(chǔ)結(jié)構(gòu)及各種算法2、熟悉用Huffman樹進(jìn)行電文的加密與解密算法二、實(shí)驗(yàn)內(nèi)容1、Huffman樹的存儲(chǔ)方式2、加密與解密算法在電文編碼中的應(yīng)用三、實(shí)驗(yàn)原理 給定n個(gè)權(quán)值作為n個(gè)葉子結(jié)點(diǎn),構(gòu)造一棵二叉樹,若帶權(quán)路徑長(zhǎng)度達(dá)到最小,稱這樣的二叉樹為最優(yōu)二叉樹,也稱為哈夫曼樹(Huffman tree)。 Huffman樹是一
2、種特殊的二叉樹,其葉結(jié)點(diǎn)的編碼是一種前綴碼,同時(shí),通過統(tǒng)計(jì)字符的頻度,能夠達(dá)到編碼電文的最小化。 哈夫曼樹的構(gòu)造 假設(shè)有n個(gè)權(quán)值,則構(gòu)造出的哈夫曼樹有n個(gè)葉子結(jié)點(diǎn)。 n個(gè)權(quán)值分別設(shè)為 w1、w2、wn,則哈夫曼樹的構(gòu)造規(guī)則為: (1) 將w1、w2、,wn看成是有n 棵樹的森林(每棵樹僅有一個(gè)結(jié)點(diǎn)); (2) 在森林中選出兩個(gè)根結(jié)點(diǎn)的權(quán)值最小的樹合并,作為一棵新樹的左、右子樹,且新樹的根結(jié)點(diǎn)權(quán)值為其左、右子樹根結(jié)點(diǎn)權(quán)值之和; (3)從森林中刪除選取的兩棵樹,并將新樹加入森林; (4)重復(fù)(2)、(3)步,直到森林中只剩一棵樹為止,該樹即為所求得的哈夫曼樹。四、實(shí)驗(yàn)步驟 1、統(tǒng)計(jì)電文中字符的出現(xiàn)
3、頻率。 2. 用統(tǒng)計(jì)頻率建立Hffman樹。 3生成前綴碼; 4建立huffman樹的解碼算法 5用隨機(jī)輸入的電文完成編碼與解碼過程。5、 程序源代碼及注釋#include #include const int MAX=20; struct huffnodeint weight;int lchild,rchild,parent;struct huffinit /輸入的權(quán)值信息的結(jié)構(gòu) char data; int weight;struct huffcode /哈夫曼樹編碼的結(jié)構(gòu) char data; char codeMAX+1;class HuffTree /哈夫曼樹類的聲明 public:
4、 HuffTree(huffinit w,int n); HuffTree() void Select(int &min1,int &min2,int m); void Output(); /輸出哈夫曼樹最終狀態(tài)(tree數(shù)組) void Encode(); /編碼 void Decode(char code); /解碼 private: huffnode tree2*MAX-1; /存儲(chǔ)哈夫曼樹 huffcode cdMAX; /存儲(chǔ)各個(gè)哈夫曼編碼 int size; /哈夫曼樹的葉子結(jié)點(diǎn)數(shù) ;HuffTree:HuffTree(huffinit w,int n) size=n;for(in
5、t i=0;i2*n-1;i+)treei.parent=-1;treei.lchild=-1;treei.rchild=-1;for(i=0;in;i+) treei.weight=wi.weight; cdi.data=wi.data; int min1=-1; int min2=-1;int m=size;for(int k=n;k2*n-1;k+) Select(min1,min2, m);treemin1.parent=k;treemin2.parent=k;treek.weight=treemin1.weight+treemin2.weight;treek.lchild=min1;
6、treek.rchild=min2;m+;void HuffTree:Select(int &min1,int &min2,int m)/選擇兩個(gè)權(quán)值最小的結(jié)點(diǎn) int a=100; int b=100; for(int i=0;im;i+) if(treei.weighta&treei.parent=-1) a=treei.weight; min1=i; for(i=0;im;i+) if(treei.weightb&treei.parent=-1&i!=min1) b=treei.weight; min2=i; void HuffTree:Output()for(int i=0;i2*si
7、ze-1;i+)couttreei.weight treei.parent treei.lchild treei.rchildendl;void HuffTree:Encode() /編碼 int m;int a;int j; char b100; int k; for(int i=0;i=0;j-) cdi.codek+=bj; cdi.codek=0; coutcdi.datacdi.codeendl; void HuffTree:Decode(char code) /解碼 int n=strlen(code); int a=2*size-2;/根節(jié)點(diǎn)的下標(biāo) for(int i=0;in;
8、i+)if(codei=0) a=treea.lchild; if(codei=1) a=treea.rchild; if(treea.lchild=-1&treea.rchild=-1) coutcda.data; a=2*size-2; elseif(codei+1=0)couterror; coutendl; void main() huffinit w20;int n;char s100;coutn;for(int i=0;in;i+) cout請(qǐng)輸入第i+1wi.data;cinwi.weight; HuffTree H(w,n); cout已經(jīng)建好的節(jié)點(diǎn)信息為endl;H.Output(); cout已經(jīng)建好的節(jié)點(diǎn)編碼信息為endl;H.Encode();char q; do couts;H.Decode(s);coutendl;coutq;while(q=Y);結(jié)果截圖: 六、實(shí)驗(yàn)結(jié)果分析及實(shí)驗(yàn)體會(huì) 通過用Huffman樹進(jìn)行編碼與解碼算法的實(shí)驗(yàn)后,對(duì)于huffman樹的理解和應(yīng)用都有了進(jìn)一步的了解,但對(duì)于快速構(gòu)建huffman樹還有些有欠純熟,還要多加煉金,并且要對(duì)基礎(chǔ)的二叉樹等知識(shí)要多加練習(xí)。注:
溫馨提示
- 1. 本站所有資源如無(wú)特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁(yè)內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫(kù)網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 2025年度智能車位共享平臺(tái)租賃合同模板4篇
- 二零二五年度內(nèi)地居民離婚后財(cái)產(chǎn)分割法律援助合同
- 2025年度美容院美容院連鎖品牌形象設(shè)計(jì)與推廣合同
- 2025年度土地承包經(jīng)營(yíng)權(quán)租賃與農(nóng)業(yè)機(jī)械化服務(wù)合同
- 二零二五年度噴漆工職業(yè)危害告知與培訓(xùn)實(shí)施合同
- 2025年無(wú)子女離婚撫養(yǎng)權(quán)協(xié)議范本子女撫養(yǎng)費(fèi)用明細(xì)12篇
- 二手車交易協(xié)議范本2024年度版版B版
- 二零二五年度變壓器租賃與電力系統(tǒng)優(yōu)化設(shè)計(jì)協(xié)議3篇
- 二零二五年度仿古茶具展覽展示與推廣服務(wù)合同3篇
- 二零二五年度安全生產(chǎn)手續(xù)代辦服務(wù)協(xié)議3篇
- 廣西桂林市2023-2024學(xué)年高二上學(xué)期期末考試物理試卷
- 財(cái)務(wù)指標(biāo)與財(cái)務(wù)管理
- 2023-2024學(xué)年西安市高二數(shù)學(xué)第一學(xué)期期末考試卷附答案解析
- 部編版二年級(jí)下冊(cè)道德與法治第三單元《綠色小衛(wèi)士》全部教案
- 【京東倉(cāng)庫(kù)出庫(kù)作業(yè)優(yōu)化設(shè)計(jì)13000字(論文)】
- 保安春節(jié)安全生產(chǎn)培訓(xùn)
- 初一語(yǔ)文上冊(cè)基礎(chǔ)知識(shí)訓(xùn)練及答案(5篇)
- 勞務(wù)合同樣本下載
- 血液透析水處理系統(tǒng)演示
- GB/T 27030-2006合格評(píng)定第三方符合性標(biāo)志的通用要求
- GB/T 13663.2-2018給水用聚乙烯(PE)管道系統(tǒng)第2部分:管材
評(píng)論
0/150
提交評(píng)論