版權說明:本文檔由用戶提供并上傳,收益歸屬內容提供方,若內容存在侵權,請進行舉報或認領
文檔簡介
1、精選文檔試驗報告與總結一、試驗目的1、 把握哈夫曼編碼原理;2、 嫻熟把握哈夫曼樹的生成方法; 3、理解數(shù)據(jù)編碼壓縮和譯碼輸出編碼的實現(xiàn)。二、試驗要求實現(xiàn)哈夫曼編碼和譯碼的生成算法。三、試驗內容先統(tǒng)計要壓縮編碼的文件中的字符字母消滅的次數(shù),按字符字母和空格消滅的概率對其進行哈夫曼編碼,然后讀入要編碼的文件,編碼后存入另一個文件;接著再調出編碼后的文件,并對其進行譯碼輸出,最終存入另一個文件中。五、試驗原理1、哈夫曼樹的定義:假設有n個權值,試構造一顆有n個葉子節(jié)點的二叉樹,每個葉子帶權值為wi,其中樹帶權路徑最小的二叉樹成為哈夫曼樹或者最優(yōu)二叉樹;2、哈夫曼樹的構造:weight為輸入的頻率數(shù)
2、組,把其中的值賦給依次建立的HT Node對象中的data屬性,即每一個HT Node對應一個輸入的頻率。然后依據(jù)data屬性按從小到大挨次排序,每次從data取出兩個最小和此次小的HT Node,將他們的data相加,構造出新的HTNode作為他們的父節(jié)點,指針parent,leftchild,rightchild賦相應值。在把這個新的節(jié)點插入最小堆。按此步驟可以構造構造出一棵哈夫曼樹。 通過已經(jīng)構造出的哈夫曼樹,自底向上,由頻率節(jié)點開頭向上查找parent,直到parent為樹的頂點為止。這樣,依據(jù)每次向上搜尋后,原節(jié)點為父節(jié)點的左孩子還是右孩子,來記錄1或0,這樣,每個頻率都會有一個01
3、編碼與之唯一對應,并且任何編碼沒有前部分是同其他完整編碼一樣的。六、試驗流程1 初始化,統(tǒng)計文本文件中各字符的個數(shù)作為權值,生成哈夫曼樹;2 依據(jù)符號概率的大小按由大到小挨次對符號進行排序; 3 把概率最小的兩個符號組成一個節(jié)點;4 重復步驟(2)(3),直到概率和為1;5 從根節(jié)點開頭到相應于每個符號的“樹葉”,概率大的標“0”,概率小的標“1”;6 從根節(jié)點開頭,對符號進行編碼;7 譯碼時流程逆向進行,從文件中讀出哈夫曼樹,并利用哈夫曼樹將編碼序列解碼。七、試驗程序#include#include#include#includeusing namespace std;typedef str
4、uct /節(jié)點結構char data; /記錄字符值long int weight; /記錄字符權重unsigned int parent,lchild,rchild;HTNode,*HuffmanTree; /動態(tài)安排數(shù)組存儲哈夫曼樹typedef char * *HuffmanCode; /動態(tài)安排數(shù)組存儲哈夫曼編碼表void Select(HuffmanTree &HT,int i,int &s1,int &s2) /在HT1.t中選擇parent不為0且權值最小的兩個結點,其序號分別為s1和s2 s1=0;s2=0;int n1=30000,n2=30000;for(int k=1;k
5、=i;k+)if(HTk.parent=0)if(HTk.weightn1)n2=n1; n1=HTk.weight;s2=s1; s1=k;elseif(HTk.weightn2)n2=HTk.weight;s2=k;void HuffmanCoding(HuffmanTree &HT,HuffmanCode &HC,int n)/將要編碼的字符串存入空樹中ifstream fin1(zifu.txt);ifstream fin2(weight.txt);if(n=1)return;int m=2*n-1;int i;HT=new HTNodem+1;char *zifu;int *weig
6、ht; zifu= new charn+1;weight=new intn+1;for(i=1;i=n;i+)/將待編碼的字符放在zifu數(shù)組中char ch;ch=fin1.get();zifui=ch;for(i=1;iweighti;for( i=1;i=n;i+)HTi.data=zifui;HTi.weight=weighti;for(i=n+1;i=m;i+)HTi.data=;for(i=1;i=m;i+)HTi.parent=HTi.lchild=HTi.rchild=0;for(i=n+1;i=m;+i)int s1,s2;Select(HT,i-1,s1,s2);HTs1.
7、parent=i; HTs2.parent=i;HTi.lchild=s1; HTi.rchild=s2;HTi.weight=HTs1.weight+HTs2.weight;HC=(HuffmanCode)malloc(n+1)*sizeof(char*);開拓一個求編碼的工作空間char *cd;cd=(char *)malloc(n*sizeof(char);/開拓空間存放權值cdn-1=0;for(i=1;i=n;i+)int start=n-1;int c,f;for( c=i, f=HTi.parent;f!=0;c=f,f=HTf.parent)/從葉子到根逆向求編碼if(HTf
8、.lchild=c)cd-start=0;/若是左孩子編為0elsecd-start=1;/若是右孩子編為1HCi=(char *)malloc(n-start)*sizeof(char); /為第i個編碼安排空間strcpy(HCi,&cdstart);delete cd; /釋放工作空間void printHuffmanTree(HuffmanTree HT,int n) /顯示有n個葉子結點的哈夫曼樹的編碼表 ofstream fout(hfmtree.txt); /將對應字符的的哈弗曼樹存入coutNUM data weight parent lchild rchlidendl;for
9、(int i=1;i=2*n-1;i+)foutHTi.weightsetw(3)HTi.parentsetw(3)HTi.lchildsetw(3)HTi.rchildendl;coutisetw(5)HTi.datasetw(3)HTi.weightsetw(3)HTi.parentsetw(3)HTi.lchildsetw(3)HTi.rchildendl;void printHuffmanCoding(HuffmanTree HT,HuffmanCode HC,int n)/輸出字符的對應哈弗曼編碼并存入code.txt文件coutHuffman code is:endl;ofstre
10、am fout(code.txt);for(int i=1;i=n;i+)coutHTi.data ;cout(HCi)endl;fout(HCi)endl;void code_file(HuffmanTree HT,HuffmanCode HC,int n)/對文件tobetran.txt進行編碼,并將編碼存入codefile文件中ifstream fin(tobetran.txt);ofstream fout(codefile.txt);vector a;char ch;while(ch=fin.get()!=*)a.push_back(ch); cout待編碼的字符串為:;for(int
11、 k=0;ka.size();k+)coutak;coutendl;coutn編碼結果:endl;for(int i=0;ia.size();i+) for(int j=1;j=n;j+)if(ai=HTj.data) foutHCj; break;fin.close();fout.close();void Decoding(HuffmanTree HT,HuffmanCode HC,int n)/打開codefile文件并對文件內容進行譯碼int const m=2*n-1;ifstream fin(codefile.txt);ofstream fout(textfile.txt);vect
12、or a;for(char c;finc;) a.push_back(c); int count=0;for(int k=0;ka.size();k+) coutak;count+;if(count%50=0)coutendl;int i=0;int p; /用p來記住m的值coutendl;coutn譯碼結果:endl;while(ia.size()p=m; /從哈弗曼數(shù)的根開頭遍歷while(HTp.lchild) if(ai=1) p=HTp.rchild; else p=HTp.lchild; i+;foutHTp.data; coutHTp.data;void main()int n
13、;coutn; printf(n);HuffmanTree HT; /哈夫曼樹HTHuffmanCode HC; /哈夫曼編碼表HCHuffmanCoding(HT,HC,n); /進行哈夫曼編碼printHuffmanCoding(HT,HC,n); /顯示編碼的字符printf(n);code_file(HT,HC,n); /顯示要編碼的字符串,并把編碼值顯示出來Decoding(HT,HC,n); /譯碼并顯示譯碼后的字符串printf(nnn);system(pause);八、結果分析哈夫曼編碼是動態(tài)變長編碼,臨時建立概率統(tǒng)計表和編碼樹。概率小的碼比較長,概率小的碼比較長。概率大的碼短,這樣把一篇文件編碼后,就會壓縮很多。從樹的角度看,哈夫曼編碼方式是盡量把短碼都利用上。首先,把一階節(jié)點全都用上,假如碼字不夠時,然后,再從某個節(jié)點伸出若干枝,引出二階節(jié)點作為碼字,以此類推,明顯所得碼長最短,再依據(jù)建立的概率統(tǒng)計表合理分布和放置,使其平均碼長最短就可以得到最佳碼。九、試驗總結通過這次試
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內容里面會有圖紙預覽,若沒有圖紙預覽就沒有圖紙。
- 4. 未經(jīng)權益所有人同意不得將文件中的內容挪作商業(yè)或盈利用途。
- 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內容本身不做任何修改或編輯,并不能對任何下載內容負責。
- 6. 下載文件中如有侵權或不適當內容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 科技進步與項目優(yōu)化
- 專利使用權及收益分配合同版B版
- 2025年度運動健身器材試用買賣服務合同4篇
- 二零二五年度大數(shù)據(jù)中心建設不可撤銷數(shù)據(jù)安全保密合同3篇
- 2025年度產(chǎn)學研產(chǎn)學研合作企業(yè)社會責任合作協(xié)議:社會責任履行與產(chǎn)業(yè)和諧發(fā)展3篇
- 2025年度文化用品場買賣合同規(guī)范文本4篇
- 二零二五年度獵頭服務與人才效能提升合作協(xié)議3篇
- 2024藥店門店店長聘用合同范本3篇
- 二零二五年度車輛租賃與車輛租賃行業(yè)規(guī)范制定協(xié)議3篇
- 專用消防設備增補協(xié)議規(guī)范文本版B版
- 2023事業(yè)單位筆試《公共基礎知識》備考題庫(含答案)
- 《水下拋石基床振動夯實及整平施工規(guī)程》
- 化學-廣東省廣州市2024-2025學年高一上學期期末檢測卷(一)試題和答案
- 2025四川中煙招聘高頻重點提升(共500題)附帶答案詳解
- 2025年云南大理州工業(yè)投資(集團)限公司招聘31人管理單位筆試遴選500模擬題附帶答案詳解
- 風電危險源辨識及控制措施
- 《教師職業(yè)道德與政策法規(guī)》課程教學大綱
- EHS工程師招聘筆試題與參考答案(某大型央企)2024年
- 營銷策劃 -麗亭酒店品牌年度傳播規(guī)劃方案
- 兒童傳染病預防課件
- 護理組長年底述職報告
評論
0/150
提交評論