版權(quán)說(shuō)明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡(jiǎn)介
1、<p> 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)報(bào)告</p><p><b> 壓縮軟件</b></p><p> ---采用哈夫曼編碼技術(shù)</p><p> 學(xué) 號(hào): </p><p> 姓 名: </p><p> 指導(dǎo)教
2、師: </p><p> 二○○七年九月七日星期五</p><p><b> 目錄</b></p><p> 目錄…………………………………………………..2</p><p> 課程設(shè)計(jì)課題……………………………………………3</p><p> 設(shè)計(jì)要求及分
3、析…………………………………………3</p><p> 軟件開(kāi)發(fā)…………………………………………………3</p><p> 軟件程序基本介紹………………………………………4</p><p> 程序代碼及功能介紹……………………………………4</p><p> ---------建立哈夫曼樹(shù)、壓縮、解壓縮</p><
4、p> 收獲與體會(huì)……………………………………………10</p><p> 附錄……………………………………………………11</p><p> 軟件使用說(shuō)明及圖示…………………………………11</p><p> 【一.】課程設(shè)計(jì)課題:</p><p><b> 壓縮軟件</b></p><
5、;p> 【二.】課程設(shè)計(jì)要求及分析:</p><p><b> 要求:</b></p><p> 準(zhǔn)備一個(gè)文件,統(tǒng)計(jì)該文件中各種字符的頻率,對(duì)各字符進(jìn)行Huffman編碼,將該文件翻譯成Huffman編碼文件,再將Huffman編碼文件翻譯成源文件。</p><p> 數(shù)據(jù)壓縮理論及哈夫曼樹(shù)簡(jiǎn)介:</p><p
6、> 數(shù)據(jù)壓縮有2種基本類型:無(wú)損壓縮和有損壓縮,使用無(wú)損壓縮方法壓縮的文件不會(huì)丟失任何信息,他與原文件具有可逆性,就是可以通過(guò)解壓縮的方法恢復(fù)原來(lái)的數(shù)據(jù),通常對(duì)文本文件,字處理文件,應(yīng)用程序等采用這種算法。有損壓縮算法在壓縮時(shí)回丟失一些信息,壓縮后不能完整恢復(fù)出原有信息,較多應(yīng)用于音頻,視頻圖象數(shù)據(jù)的處理。</p><p> 此處我們所實(shí)現(xiàn)的是哈夫曼算法,在計(jì)算機(jī)信息處理中,哈夫曼編碼是一種變長(zhǎng)編碼法(
7、又稱“熵編碼法”),用于數(shù)據(jù)的無(wú)損壓縮著一術(shù)語(yǔ)是指用一張?zhí)厥獾木幋a表對(duì)源字符進(jìn)行編碼。這張編碼表的特殊之處在于,它是根據(jù)每一個(gè)源字符出現(xiàn)的估算概率而建立起來(lái)的(出現(xiàn)頻率高的字符使用教短的編碼,出現(xiàn)頻率高的則使用教長(zhǎng)的,使編碼后的字符串的平均期望長(zhǎng)度降低,從而達(dá)到無(wú)損壓縮數(shù)據(jù)的目的),同時(shí)保持編碼的唯一可解性,這種方法是由美國(guó)科學(xué)家David.A.Huffman發(fā)展起來(lái)的。哈夫曼樹(shù)是哈夫曼算法的理論描述工具,也稱最優(yōu)二叉樹(shù),是一種加權(quán)路徑
8、長(zhǎng)度最短的二叉樹(shù)。加權(quán)路徑長(zhǎng)度是指樹(shù)中所有葉子結(jié)點(diǎn)的權(quán)值乘上其到根結(jié)點(diǎn)的路徑長(zhǎng)度。N個(gè)葉子結(jié)點(diǎn)的哈夫曼樹(shù)共有2n-1個(gè)結(jié)點(diǎn),這個(gè)性質(zhì)將運(yùn)用于使用數(shù)組結(jié)構(gòu)存儲(chǔ)哈夫曼樹(shù),從根結(jié)點(diǎn)開(kāi)始,左子結(jié)點(diǎn)分配0,右子結(jié)點(diǎn)分配1,沿著樹(shù)根到各個(gè)結(jié)點(diǎn)就得到了哈夫曼編碼,因?yàn)樗斜痪幋a的字符都作為葉子結(jié)點(diǎn)出現(xiàn)而每個(gè)葉子結(jié)點(diǎn)路徑又是獨(dú)立的,保障了每個(gè)編碼都不會(huì)四其余碼的前綴,這樣的編碼又稱“哈夫曼無(wú)重復(fù)前綴編碼”,著在下面的程序段會(huì)應(yīng)用到。</p>
9、<p> 哈夫曼樹(shù)也應(yīng)用于譯碼過(guò)程,譯碼過(guò)程中逐一掃描碼文,從哈夫曼的根結(jié)點(diǎn)開(kāi)始,將掃描得到的二進(jìn)制位串中的相鄰位與哈夫曼樹(shù)上的0,1匹配。</p><p><b> 需求分析:</b></p><p> 設(shè)計(jì)目標(biāo)是要實(shí)現(xiàn)哈夫曼壓縮的編碼器和譯碼器。碼器工作如下:首先讀入待壓縮文件為了保證與原文件信息完全一致,對(duì)文件的讀寫(xiě)都采用二進(jìn)制的方式進(jìn)行。然
10、后建立并分析字母表,最多只有256種可能的符,對(duì)每種字符出現(xiàn)的頻度進(jìn)行統(tǒng)計(jì),以頻度作為建立哈夫曼樹(shù)的權(quán)值。頻度表建立好以后,可以建立哈夫曼樹(shù),對(duì)出現(xiàn)的每種字符進(jìn)行哈夫曼編碼。此時(shí)再讀入原文件,逐個(gè)字節(jié)進(jìn)行編碼,將得到的編碼流逐個(gè)寫(xiě)入文件。譯碼過(guò)程相對(duì)簡(jiǎn)單:讀入被壓縮文件,將其解釋為比特流,根據(jù)哈夫曼樹(shù)對(duì)比特流逐個(gè)譯碼,將譯碼結(jié)果逐個(gè)寫(xiě)到磁盤(pán)文件。</p><p><b> 【三.】軟件開(kāi)發(fā):</
11、b></p><p> 該軟件是在Visual C++6.0環(huán)境下編譯和運(yùn)行的,運(yùn)行時(shí)可以直接雙擊圖標(biāo): 。Visual C++6.0是在Windows環(huán)境下運(yùn)行C++的集成環(huán)境。Visual C++6.0由許多組件組成,包括編輯器、調(diào)試器以及程序向?qū)ppWizard、類向?qū)lass Wizard等開(kāi)發(fā)工具。 這些組件通過(guò)一個(gè)名為Developer Studio的組件集成為和諧的開(kāi)發(fā)環(huán)境。</p
12、><p> 【四.】軟件程序基本介紹:</p><p> 該壓縮軟件程序結(jié)構(gòu)采用的是1個(gè)CPP文件和一個(gè)HEAD文件,界面采用菜單提示輸入。</p><p> 【五.】程序代碼及功能介紹:</p><p><b> 1.函數(shù)結(jié)構(gòu)</b></p><p> 在head.h文件中共有3個(gè)函數(shù),分
13、別為:void Select(int k,int &s1,int &s2)</p><p> void compress()</p><p> void uncompress()</p><p> 其中void Select(int k,int &s1,int &s2)是在void compress()中調(diào)用的,他的功能是在K個(gè)
14、元素中選擇權(quán)值最小的兩個(gè)結(jié)點(diǎn)S1,S2;</p><p> void compress()和void uncompress()是在a.cpp的main函數(shù)中被調(diào)用的,他們的功能分別是壓縮和解壓縮。</p><p> 2.函數(shù)結(jié)構(gòu)圖如下:</p><p><b> 3.?dāng)?shù)據(jù)結(jié)構(gòu)設(shè)計(jì)</b></p><p> 哈夫曼
15、算法的實(shí)現(xiàn)可以采用鏈表結(jié)構(gòu)生成哈夫曼樹(shù),但是效率比較低,也可以使用堆排序,這里采用的是線形表的順序存儲(chǔ)結(jié)構(gòu):</p><p> struct head </p><p><b> {</b></p><p> unsigned char b; //記錄字符在數(shù)組中的位置</p><p> l
16、ong count; //字符出現(xiàn)頻率(權(quán)值) </p><p> long parent,lch,rch; //定義哈夫曼樹(shù)指針變量 </p><p> char bits[256]; //定義存儲(chǔ)哈夫曼編碼的數(shù)組</p><p><b> } </b></p><p&g
17、t; 該存儲(chǔ)結(jié)構(gòu)在二叉樹(shù)中的結(jié)點(diǎn)結(jié)構(gòu)如下:</p><p><b> 4.功能設(shè)計(jì)</b></p><p> compress函數(shù):</p><p> 該函數(shù)將完成壓縮目標(biāo)文件的功能,首先輸入文件名,讀取目標(biāo)文件ifp=fopen(filename,"rb"),這里”rb”是按二進(jìn)制方式進(jìn)行讀操作,輸入壓縮后的文件名
18、fopen(outputfile,"wb"),其中”wb”是打開(kāi)或建立一個(gè)二進(jìn)制文件,只允許寫(xiě)數(shù)據(jù)。(filename為需要壓縮的文件名,outputfile為完成壓縮后的文件名)</p><p> while(!feof(ifp))</p><p><b> {</b></p><p> fread(&c,1
19、,1,ifp); </p><p> fread(buffer,size,count,fp),</p><p> header[c].count++; //字符重復(fù)出現(xiàn)頻率加1</p><p> flength++; //出現(xiàn)字符則原文長(zhǎng)度加1</p><p><b> }</b><
20、;/p><p> feof()為文件檢測(cè)函數(shù),若文件沒(méi)有結(jié)束返回是0,當(dāng)文件結(jié)束時(shí)返回1。</p><p> fread()是從一個(gè)流中讀數(shù)據(jù),fread(buffer,size,count,fp),其中buffer是一個(gè)指針,在fread函數(shù)中,它表示存放輸入數(shù)據(jù)的首地址。 size 表示數(shù)據(jù)塊的字節(jié)數(shù)。count 表示要讀寫(xiě)的數(shù)據(jù)塊塊數(shù)。fp 表示文件指針。 </p>&
21、lt;p> for(i=0;i<512;i++) </p><p><b> {</b></p><p> if(header[i].count!=0) header[i].b=(unsigned char)i; //如果該字符出現(xiàn)過(guò),將他的哈夫曼碼值及其對(duì)應(yīng)的ASCII碼存放在一維數(shù)組header[i]中,且編碼表中的下標(biāo)和ASCII碼滿足順序存放
22、關(guān)系。</p><p> else header[i].b=0; </p><p> header[i].parent=header[i].lch=header[i].rch=-1; //是對(duì)結(jié)點(diǎn)進(jìn)行初始化。</p><p><b> } </b></p><p><b> 建立哈夫曼樹(shù):</b&
23、gt;</p><p> for(i=0;i<256;i++) //根據(jù)頻率(權(quán)值)大小,對(duì)結(jié)點(diǎn)進(jìn)行排序,選擇較小的結(jié)點(diǎn)進(jìn)樹(shù)。</p><p><b> {</b></p><p> for(j=i+1;j<256;j++)</p><p><b> {</b></p
24、><p> if(header[i].count<header[j].count)</p><p><b> {</b></p><p> tmp=header[i];</p><p> header[i]=header[j]; </p><p> header[j]=tmp; <
25、;/p><p><b> } </b></p><p><b> } </b></p><p><b> }</b></p><p> 根據(jù)哈夫曼樹(shù)的性質(zhì),n個(gè)葉子結(jié)點(diǎn)(權(quán))需要2n-1個(gè)結(jié)點(diǎn)來(lái)構(gòu)建一棵哈夫曼樹(shù):</p><p> for(i=n;
26、i<m;i++) </p><p><b> {</b></p><p> Select(i-1,s1,s2);</p><p> header[s1].parent=header[s2].parent=i;</p><p> header[i].lch=s1;</p><p>
27、 header[i].rch=s2;</p><p> header[i].count=header[s1].count+header[s2].count;</p><p><b> }</b></p><p> header[i].lch=s1; //計(jì)算左分支權(quán)值大??;</p><p> head
28、er[i].rch=s2; //計(jì)算右分支權(quán)值大小;</p><p> header[s1].parent=header[s2].parent=i;依據(jù)parent域值(結(jié)點(diǎn)層數(shù))確定樹(shù)中結(jié)點(diǎn)之間的關(guān)系;</p><p> header[i].count=header[s1].count+header[s2].count; //父結(jié)點(diǎn)的權(quán)值為其左孩子和右孩子權(quán)值之和;<
29、/p><p> 構(gòu)建哈夫曼樹(shù)時(shí)用到了一個(gè)Select()函數(shù):在K個(gè)元素中選擇父結(jié)點(diǎn)不為-1的權(quán)值最小的兩個(gè)結(jié)點(diǎn)S1,S2;</p><p> void Select(int k,int &s1,int &s2)</p><p><b> {</b></p><p><b> s1,s2=0
30、;</b></p><p> long min1=9999999;</p><p> for(int j=1;j<k;j++)</p><p> if (header[j].parent!=-1) </p><p><b> {</b></p><p> if (hea
31、der[j].count<header[s1].count)</p><p><b> {</b></p><p><b> s2=s1;</b></p><p><b> s1=j;</b></p><p><b> }</b></p
32、><p> elseif(header[j].count<header[s2].count)</p><p><b> s2=j;</b></p><p><b> }</b></p><p><b> }</b></p><p> lon
33、g min1=9999999;假設(shè)字符出現(xiàn)頻率的最大值(最大權(quán)值),比較如下圖:</p><p> 哈夫曼無(wú)重復(fù)前綴編碼:</p><p> for(i=0;i<n;i++) </p><p><b> {</b></p><p><b> f=i; </b></p>
34、<p> header[i].bits[0]=0; </p><p> while(header[f].parent!=-1) </p><p><b> {</b></p><p><b> j=f; </b></p><p> f=header[f].parent; &l
35、t;/p><p> if(header[f].lch==j) //置左分支編碼0;</p><p><b> {</b></p><p> j=strlen(header[i].bits); </p><p> memmove(header[i].bits+1,header[i].bits,j+1); //依次存
36、儲(chǔ)連接”0””1”編碼;</p><p> header[i].bits[0]='0'; </p><p><b> }</b></p><p> else //置右分支編碼1</p><p><b> {</b></p><p> j=strle
37、n(header[i].bits); </p><p> memmove(header[i].bits+1,header[i].bits,j+1); </p><p> header[i].bits[0]='1'; </p><p><b> } </b></p><p><b> }
38、</b></p><p><b> }</b></p><p> 其中header[i].bits[0]=0;根結(jié)點(diǎn)編碼0。</p><p> 將編碼好的數(shù)據(jù)寫(xiě)入文件:</p><p> fseek(ifp,0,SEEK_SET); 從文件開(kāi)始位置向前移動(dòng)0字節(jié),即定位到文件開(kāi)始位置</p&
39、gt;<p> fwrite(&flength,sizeof(int),1,ofp); 用來(lái)將數(shù)據(jù)寫(xiě)入文件流中,參數(shù)flength指向欲寫(xiě)入的數(shù)據(jù)地址, 總共寫(xiě)入的字符數(shù)以參數(shù)size*int來(lái)決定,返回實(shí)際寫(xiě)入的int數(shù)目;</p><p> buf[0]=0;定義緩沖區(qū),它的二進(jìn)制表示00000000。</p><p> while(!feof(ifp))
40、</p><p><b> {</b></p><p> c=fgetc(ifp); </p><p><b> f++; </b></p><p> for(i=0;i<n;i++) </p><p><b> {</b></p&
41、gt;<p> if(c==header[i].b) break; </p><p><b> }</b></p><p> strcat(buf,header[i].bits); </p><p> j=strlen(buf);</p><p><b> c=0; </b>
42、</p><p> 下面對(duì)哈夫曼編碼位操作進(jìn)行壓縮存儲(chǔ):</p><p> while(j>=8) </p><p><b> {</b></p><p> for(i=0;i<8;i++) </p><p><b> {</b></p>
43、;<p> if(buf[i]=='1') c=(c<<1)|1; </p><p> else c=c<<1; </p><p><b> }</b></p><p> fwrite(&c,1,1,ofp); </p><p><b>
44、pt1++; </b></p><p> strcpy(buf,buf+8); </p><p> j=strlen(buf); </p><p><b> }</b></p><p> if(f==flength) break; </p><p><b> }
45、</b></p><p> 其中strcpy(buf,buf+8);是將一個(gè)字節(jié)一個(gè)字節(jié)地拼接起來(lái),pt1是統(tǒng)計(jì)壓縮以后文件長(zhǎng)度的。</p><p> 對(duì)哈夫曼編碼位操作進(jìn)行壓縮存儲(chǔ):</p><p><b> if(j>0) </b></p><p><b> {</b>
46、;</p><p> strcat(buf,"00000000"); </p><p> for(i=0;i<8;i++) </p><p><b> {</b></p><p> if(buf[i]=='1') c=(c<<1)|1; </p>
47、<p> else c=c<<1; </p><p><b> }</b></p><p> fwrite(&c,1,1,ofp); </p><p><b> pt1++; </b></p><p><b> }</b></p&
48、gt;<p><b> 數(shù)據(jù)寫(xiě)入:</b></p><p> for(i=0;i<n;i++) </p><p><b> {</b></p><p> fwrite(&(header[i].b),1,1,ofp); </p><p> c=strlen(hea
49、der[i].bits); </p><p> fwrite(&c,1,1,ofp); </p><p> j=strlen(header[i].bits); </p><p> if(j%8!=0) 若存儲(chǔ)的位數(shù)不是8的倍數(shù),則補(bǔ)0;</p><p><b> {</b></p><
50、;p> for(f=j%8;f<8;f++) </p><p> strcat(header[i].bits,"0"); </p><p><b> }</b></p><p> while(header[i].bits[0]!=0) </p><p><b> {&l
51、t;/b></p><p><b> c=0; </b></p><p> for(j=0;j<8;j++) //字符的有效存儲(chǔ)不超過(guò)8位,則對(duì)有效位數(shù)左移實(shí)現(xiàn)兩字符編碼的連接</p><p><b> {</b></p><p> if(header[i].bits[j]
52、=='1') c=(c<<1)|1; // |1不改變?cè)恢蒙系?quot;0""1"值;</p><p> else c=c<<1; </p><p><b> }</b></p><p> strcpy(header[i].bits,header[i].bits+
53、8); //把字符的編碼按原先存儲(chǔ)順序連接。</p><p> fwrite(&c,1,1,ofp); </p><p><b> } </b></p><p><b> }</b></p><p> uncompress函數(shù):</p><p> 該函數(shù)
54、完成的功能是將一個(gè)目標(biāo)壓縮文件解壓還原,首先輸入文件名,讀取目標(biāo)文件ifp=fopen(filename,"rb"),這里”rb”是按二進(jìn)制方式進(jìn)行讀操作,輸入壓縮后的文件名fopen(outputfile,"wb"),其中”wb”是打開(kāi)或建立一個(gè)二進(jìn)制文件,只允許寫(xiě)數(shù)據(jù)。</p><p> fread(&flength,sizeof(long),1,ifp);讀
55、取原文件長(zhǎng)度,對(duì)文件進(jìn)行定位。</p><p> fread(&f,sizeof(long),1,ifp); </p><p> fseek(ifp,f,SEEK_SET); </p><p> fread(&n,sizeof(long),1,ifp); </p><p> for(i=0;i<n;i++) &l
56、t;/p><p><b> {</b></p><p> fread(&header[i].b,1,1,ifp); </p><p> fread(&c,1,1,ifp); </p><p> p=(long)c; 讀取原文件字符的權(quán)值;</p><p> header[i
57、].count=p; </p><p> header[i].bits[0]=0; </p><p> if(p%8>0) m=p/8+1; </p><p> else m=p/8; </p><p> for(j=0;j<m;j++) </p><p><b> {</b>
58、;</p><p> fread(&c,1,1,ifp); </p><p><b> f=c; </b></p><p> itoa(f,buf,2); //將f轉(zhuǎn)換為二進(jìn)制表示的字符串</p><p> f=strlen(buf); </p><p> for(l=8;l&g
59、t;f;l--) </p><p><b> {</b></p><p> strcat(header[i].bits,"0"); </p><p><b> }</b></p><p> strcat(header[i].bits,buf); </p>&
60、lt;p><b> } </b></p><p> header[i].bits[p]=0; </p><p><b> }</b></p><p> for(i=0;i<n;i++) //根據(jù)哈夫曼編碼的長(zhǎng)短,對(duì)結(jié)點(diǎn)進(jìn)行排序:</p><p><b> {<
61、;/b></p><p> for(j=i+1;j<n;j++) </p><p><b> {</b></p><p> if(strlen(header[i].bits)>strlen(header[j].bits)) </p><p><b> {</b></p
62、><p> tmp=header[i]; </p><p> header[i]=header[j]; </p><p> header[j]=tmp; </p><p><b> } </b></p><p><b> } </b></p><p&
63、gt;<b> } </b></p><p><b> 解碼:</b></p><p> 通過(guò)哈夫曼編碼的長(zhǎng)短,依次解碼,從原來(lái)的位存儲(chǔ)還原到字節(jié)存儲(chǔ)</p><p><b> while(1) </b></p><p><b> {</b>&l
64、t;/p><p> while(strlen(bx)<(unsigned int)p) </p><p><b> {</b></p><p> fread(&c,1,1,ifp); </p><p><b> f=c; </b></p><p> ito
65、a(f,buf,2); </p><p> f=strlen(buf); </p><p> for(l=8;l>f;l--) //在單字節(jié)內(nèi)對(duì)相應(yīng)位置補(bǔ)0</p><p><b> {</b></p><p> strcat(bx,"0"); </p><p>
66、<b> }</b></p><p> strcat(bx,buf); </p><p><b> }</b></p><p> for(i=0;i<n;i++) </p><p><b> {</b></p><p> if(memc
67、mp(header[i].bits,bx,header[i].count)==0) break; </p><p><b> }</b></p><p> strcpy(bx,bx+header[i].count); //從壓縮文件中的按位存儲(chǔ)還原到按字節(jié)存儲(chǔ)字符,字符位置不改變;</p><p> c=header[i].b; <
68、;/p><p> fwrite(&c,1,1,ofp); </p><p> m++; //m是用來(lái)統(tǒng)計(jì)解壓后的文件長(zhǎng)度</p><p> if(m==flength) break; //flength是原文件長(zhǎng)度; </p><p><b> }</b></p><p> fc
69、lose(ifp); </p><p> fclose(ofp);關(guān)閉文件。</p><p><b> 【六】收獲與體會(huì)</b></p><p> 1.靜態(tài)哈夫曼編碼方法有一些缺點(diǎn):對(duì)于過(guò)短的文件進(jìn)行編碼的意義不大,因?yàn)楣庖?BYTES的長(zhǎng)度存儲(chǔ)哈夫曼樹(shù)的信息就需1024Bytes的存儲(chǔ)空間;</p><p>
70、2.對(duì)較大的文件進(jìn)行編碼時(shí),頻繁的磁盤(pán)讀寫(xiě)訪問(wèn)會(huì)降低數(shù)據(jù)編碼的速度。經(jīng)過(guò)網(wǎng)上查詢已經(jīng)有了改進(jìn)之法--動(dòng)態(tài)的哈夫曼編碼方法。動(dòng)態(tài)哈夫曼編碼使用一棵動(dòng)態(tài)變化的哈夫曼樹(shù),對(duì)第t+1個(gè)字符的編碼是根據(jù)原始數(shù)據(jù)中前t個(gè)字符得到的哈夫曼樹(shù)來(lái)進(jìn)行的,編碼和解碼使用相同的初始哈夫曼樹(shù),每處理完一個(gè)字符,編碼和解碼使用相同的方法修改哈夫曼樹(shù),所以沒(méi)有必要為解碼而保存哈夫曼樹(shù)的信息。編碼和解碼一個(gè)字符所需的時(shí)間與該字符的編碼長(zhǎng)度成正比,所以動(dòng)態(tài)哈夫曼編碼可
71、實(shí)時(shí)進(jìn)行。動(dòng)態(tài)哈夫曼編碼比靜態(tài)哈夫曼編碼復(fù)雜的多;</p><p> 3.哈夫曼樹(shù)是哈夫曼編碼的應(yīng)用,也是編碼和譯碼的核心,是連接編碼和譯碼的紐帶。該壓縮軟件采用的正是哈夫曼算法,建立哈夫曼樹(shù),對(duì)原文件中的字符進(jìn)行哈夫曼編碼,通過(guò)將哈夫曼算法應(yīng)用與壓縮軟件,更進(jìn)一步理解哈夫曼樹(shù)的建立和對(duì)各個(gè)葉子結(jié)點(diǎn)的編碼。哈夫曼壓縮技術(shù)對(duì)文本文件壓縮效率很高,對(duì)于2進(jìn)制文件這種方法也很成功,但壓縮比沒(méi)有那么顯著;</p&
72、gt;<p> 4.編碼不是唯一的,但用你的代碼算出來(lái)的是唯一的,所以傳輸一定要用自己的代碼解碼,構(gòu)造好哈夫曼樹(shù)后,就可根據(jù)哈夫曼樹(shù)進(jìn)行編碼。例如:字符根據(jù)其出現(xiàn)的概率作為權(quán)值構(gòu)造一棵哈夫曼樹(shù)后,經(jīng)哈夫曼編碼得到的對(duì)應(yīng)的碼值。只要使用同一棵哈夫曼樹(shù),就可把編碼還原成原來(lái)那組字符;</p><p> 5.該程序中因?yàn)樯婕拔募僮?,多次讀寫(xiě)文件,為了保證操作后的文件與原文件的一致性,在打開(kāi)或者建立新
73、文件時(shí)都是以二進(jìn)制進(jìn)行操作,著不僅加深了我們對(duì)文件操作的理解,也在程序中體現(xiàn)了完整性,并且將解壓后的文件和原文件相比較具有一致性,體現(xiàn)的程序的健壯性。</p><p><b> 【七】附錄</b></p><p><b> 源程序文件名清單:</b></p><p> head.h
74、 //完成壓縮和解壓功能函數(shù)</p><p> a.cpp //主函數(shù)</p><p> 附:軟件使用說(shuō)明及圖示:</p><p> 一.使用說(shuō)明:該壓縮軟件的使用界面十分簡(jiǎn)明,運(yùn)行環(huán)境為DOS操作系統(tǒng),進(jìn)入界面后,就會(huì)提示輸入字符串的輸入形式,結(jié)束符為“回車(chē)符”。分3個(gè)功能選項(xiàng):1壓縮 2解壓 3退出,選擇1或者2時(shí)都會(huì)有
75、語(yǔ)句提醒你輸入被壓縮(解壓)的目標(biāo)文件名及壓縮(解壓)后的生成文件名。</p><p> 二.使用注意:壓縮的目標(biāo)文檔需要在當(dāng)前文件夾下,使用時(shí)可以直接輸入文件名(加后綴),解壓后的文件名同理。</p><p><b> 三.圖示:</b></p><p><b> 原始菜單界面:</b></p>&l
溫馨提示
- 1. 本站所有資源如無(wú)特殊說(shuō)明,都需要本地電腦安裝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ù)覽,若沒(méi)有圖紙預(yù)覽就沒(méi)有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 眾賞文庫(kù)僅提供信息存儲(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ì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)報(bào)告
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)報(bào)告
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)報(bào)告
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)報(bào)告
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)報(bào)告
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)報(bào)告
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)報(bào)告
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)報(bào)告
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)報(bào)告
- 《數(shù)據(jù)結(jié)構(gòu)》課程設(shè)計(jì)報(bào)告
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)報(bào)告
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)--數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)----huffman編碼
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)——課程設(shè)計(jì)報(bào)告模板
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)報(bào)告 (2)
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)實(shí)習(xí)報(bào)告
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)報(bào)告.doc
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)報(bào)告 (3)
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)報(bào)告 (2)
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)報(bào)告 (2)
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)報(bào)告--鏈表
評(píng)論
0/150
提交評(píng)論