




版權(quán)說(shuō)明:本文檔由用戶(hù)提供并上傳,收益歸屬內(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) 告課程名稱(chēng) 數(shù)據(jù)結(jié)構(gòu) 實(shí)驗(yàn)項(xiàng)目 用Huffman樹(shù)進(jìn)行編碼與解碼算法 專(zhuān)業(yè)班級(jí) 網(wǎng)絡(luò)工程2 姓 名 陳浩明 學(xué) 號(hào) 2010394223 指導(dǎo)教師 成 績(jī) 日 期 1、 實(shí)驗(yàn)?zāi)康?1、通過(guò)本實(shí)驗(yàn),熟悉二叉樹(shù)、Huffman樹(shù)的基本概念,掌握二叉樹(shù)的存儲(chǔ)結(jié)構(gòu)及各種算法2、熟悉用Huffman樹(shù)進(jìn)行電文的加密與解密算法二、實(shí)驗(yàn)內(nèi)容1、Huffman樹(shù)的存儲(chǔ)方式2、加密與解密算法在電文編碼中的應(yīng)用三、實(shí)驗(yàn)原理 給定n個(gè)權(quán)值作為n個(gè)葉子結(jié)點(diǎn),構(gòu)造一棵二叉樹(shù),若帶權(quán)路徑長(zhǎng)度達(dá)到最小,稱(chēng)這樣的二叉樹(shù)為最優(yōu)二叉樹(shù),也稱(chēng)為哈夫曼樹(shù)(Huffman tree)。 Huffman樹(shù)是一
2、種特殊的二叉樹(shù),其葉結(jié)點(diǎn)的編碼是一種前綴碼,同時(shí),通過(guò)統(tǒng)計(jì)字符的頻度,能夠達(dá)到編碼電文的最小化。 哈夫曼樹(shù)的構(gòu)造 假設(shè)有n個(gè)權(quán)值,則構(gòu)造出的哈夫曼樹(shù)有n個(gè)葉子結(jié)點(diǎn)。 n個(gè)權(quán)值分別設(shè)為 w1、w2、wn,則哈夫曼樹(shù)的構(gòu)造規(guī)則為: (1) 將w1、w2、,wn看成是有n 棵樹(shù)的森林(每棵樹(shù)僅有一個(gè)結(jié)點(diǎn)); (2) 在森林中選出兩個(gè)根結(jié)點(diǎn)的權(quán)值最小的樹(shù)合并,作為一棵新樹(shù)的左、右子樹(shù),且新樹(shù)的根結(jié)點(diǎn)權(quán)值為其左、右子樹(shù)根結(jié)點(diǎn)權(quán)值之和; (3)從森林中刪除選取的兩棵樹(shù),并將新樹(shù)加入森林; (4)重復(fù)(2)、(3)步,直到森林中只剩一棵樹(shù)為止,該樹(shù)即為所求得的哈夫曼樹(shù)。四、實(shí)驗(yàn)步驟 1、統(tǒng)計(jì)電文中字符的出現(xiàn)
3、頻率。 2. 用統(tǒng)計(jì)頻率建立Hffman樹(shù)。 3生成前綴碼; 4建立huffman樹(shù)的解碼算法 5用隨機(jī)輸入的電文完成編碼與解碼過(guò)程。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 /哈夫曼樹(shù)編碼的結(jié)構(gòu) char data; char codeMAX+1;class HuffTree /哈夫曼樹(shù)類(lèi)的聲明 public:
4、 HuffTree(huffinit w,int n); HuffTree() void Select(int &min1,int &min2,int m); void Output(); /輸出哈夫曼樹(shù)最終狀態(tài)(tree數(shù)組) void Encode(); /編碼 void Decode(char code); /解碼 private: huffnode tree2*MAX-1; /存儲(chǔ)哈夫曼樹(shù) huffcode cdMAX; /存儲(chǔ)各個(gè)哈夫曼編碼 int size; /哈夫曼樹(shù)的葉子結(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ì) 通過(guò)用Huffman樹(shù)進(jìn)行編碼與解碼算法的實(shí)驗(yàn)后,對(duì)于huffman樹(shù)的理解和應(yīng)用都有了進(jìn)一步的了解,但對(duì)于快速構(gòu)建huffman樹(shù)還有些有欠純熟,還要多加煉金,并且要對(duì)基礎(chǔ)的二叉樹(shù)等知識(shí)要多加練習(xí)。注:
溫馨提示
- 1. 本站所有資源如無(wú)特殊說(shuō)明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶(hù)所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁(yè)內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒(méi)有圖紙預(yù)覽就沒(méi)有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫(kù)網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶(hù)上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶(hù)上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶(hù)因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 2025年間甲氧基笨硫酚項(xiàng)目可行性研究報(bào)告
- 2025年度養(yǎng)老護(hù)理員職業(yè)發(fā)展規(guī)劃合同協(xié)議
- 2025年度員工保密及競(jìng)業(yè)禁止協(xié)議補(bǔ)充合同
- 二零二五年度聯(lián)合體合作協(xié)議-海洋資源開(kāi)發(fā)與保護(hù)
- 2025年度人工智能技術(shù)研發(fā)全新期權(quán)合同
- 二零二五年度精裝修住宅購(gòu)房合同委托書(shū)
- 體育館室內(nèi)設(shè)計(jì)委托協(xié)議
- 2025年度商業(yè)地產(chǎn)商用租房租賃及可持續(xù)發(fā)展戰(zhàn)略合同
- 2025年配電箱外殼行業(yè)深度研究分析報(bào)告
- 二零二五年度藥房新零售店員工聘用及培訓(xùn)合同
- 福建省服務(wù)區(qū)標(biāo)準(zhǔn)化設(shè)計(jì)指南
- 銷(xiāo)售人員薪酬設(shè)計(jì)實(shí)例 薪酬制度設(shè)計(jì) 薪酬設(shè)計(jì)方案 設(shè)計(jì)案例全套
- 福特F-150猛禽說(shuō)明書(shū)
- 征地搬遷基本要求及工作技巧課件
- 部編版語(yǔ)文五年級(jí)下冊(cè) 課本解讀
- 中國(guó)畫(huà)的特點(diǎn)及分類(lèi)課件
- 供應(yīng)商現(xiàn)場(chǎng)審核評(píng)估表
- 自身免疫性多內(nèi)分泌腺體綜合征
- IEC-60068-系列標(biāo)準(zhǔn)完整版
- 鳳飛羌舞演藝中心及演出項(xiàng)目可行性研究報(bào)告
- 工程電磁場(chǎng)教案
評(píng)論
0/150
提交評(píng)論