版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡(jiǎn)介
文件壓縮第十組問題描述在信息通信過程中,我們需要傳輸大量文件。在大的文件中有許多冗余,為了提高信道利用率、縮短信息傳輸時(shí)間、降低傳輸成本,我們?cè)O(shè)計(jì)一個(gè)編譯系統(tǒng),發(fā)送方利用哈夫曼編碼對(duì)文件進(jìn)行壓縮后傳輸,接收方將接收到的數(shù)據(jù)進(jìn)行譯碼。第2
頁(yè)設(shè)計(jì)要求分析(1)保存:傳輸文件存于文本文件中,如:源文件textfile(2)預(yù)處理:從文件中讀取數(shù)據(jù),處理并建立字符集頻率表(3)初始化:利用字符集頻率表建立哈夫曼樹(4)編碼:利用建立好的哈夫曼樹對(duì)源文件進(jìn)行編碼,實(shí)現(xiàn)文件壓縮,然后將結(jié)果以文件形式保存,如編碼文件codefile(5)譯碼:利用建立好的哈夫曼樹對(duì)codefile中的代碼進(jìn)行譯碼。結(jié)果存入譯碼文件decofile中。(6)輸出:可以顯示testfile、codefile、decofile和哈夫曼樹第3
頁(yè)數(shù)據(jù)結(jié)構(gòu)與算法分析(一)利用字符和權(quán)值建立哈夫曼樹求得哈夫曼編碼(二)利用二叉樹先序遍歷輸出哈夫曼樹第4
頁(yè)系統(tǒng)各部分詳細(xì)設(shè)計(jì)及實(shí)現(xiàn)一、
哈夫曼樹類定義
classHaffmanCode{private: intnum;//字符集個(gè)數(shù) Node*ht;//哈夫曼樹 HaffCode*hc;//哈夫曼碼
public: HaffmanCode():num(0),ht(NULL),hc(NULL){};~HaffmanCode();第5
頁(yè)系統(tǒng)各部分詳細(xì)設(shè)計(jì)及實(shí)現(xiàn) voidbuildHfmtree(charstr[],intw[],intn);//構(gòu)
造哈夫曼樹
voidHfmcode(charstr[]);//由哈夫曼樹生成哈
夫曼編碼
voidencoding(); voiddecoding(); voidprintcode(); voidprinttree();//打印樹的實(shí)例函數(shù) voidprinttree(fstream&outfile,intn,intlen);//
打印樹的遞歸函數(shù) intloct(charc);//查找字符c所在的下標(biāo)第6
頁(yè)系統(tǒng)各部分詳細(xì)設(shè)計(jì)及實(shí)現(xiàn)二、建立哈夫曼樹(一)構(gòu)造哈夫曼樹
voidHaffmanCode::buildHfmtree(charstr[],intw[],intn){ num=n; ht=newNode[2*n-1]; hc=newHaffCode[n]; inti,j,m1,m2;//m1、m2分別表示最小、次小的權(quán)值 intx1,x2;//x1、x2分別表示當(dāng)前分支結(jié)點(diǎn)的左右兒子第7
頁(yè)系統(tǒng)各部分詳細(xì)設(shè)計(jì)及實(shí)現(xiàn)for(i=0;i<2*n-1;i++)//哈夫曼樹初始化 { if(i<n) ht[i].weight=w[i]; else ht[i].weight=0; ht[i].parent=-1; ht[i].lchild=-1; ht[i].rchild=-1; }第8
頁(yè)系統(tǒng)各部分詳細(xì)設(shè)計(jì)及實(shí)現(xiàn)for(i=0;i<n-1;i++)//構(gòu)造哈夫曼樹的 n-1個(gè)分支結(jié)點(diǎn) { m1=m2=1000; x1=x2=0; for(j=0;j<n+i;j++) { //在沒掛進(jìn)哈夫曼樹的節(jié)點(diǎn)中尋找權(quán)值最小的節(jié)點(diǎn) if(ht[j].parent==-1&&ht[j].weight<m1)第9
頁(yè)系統(tǒng)各部分詳細(xì)設(shè)計(jì)及實(shí)現(xiàn){ m2=m1;//最小保存到次小 x2=x1; m1=ht[j].weight; x1=j; } elseif(ht[j].parent==-1&&ht[j].weight<m2) {第10
頁(yè)系統(tǒng)各部分詳細(xì)設(shè)計(jì)及實(shí)現(xiàn)m2=ht[j].weight; x2=j; } } ht[x1].parent=n+i; ht[x2].parent=n+i; ht[n+i].weight=ht[x1].weight+ht[x2].weight; ht[n+i].lchild=x1; ht[n+i].rchild=x2;第11
頁(yè)系統(tǒng)各部分詳細(xì)設(shè)計(jì)及實(shí)現(xiàn)(二)由哈夫曼樹生成哈夫曼編碼voidHaffmanCode::Hfmcode(charstr[]){ HaffCodecd; intchild,parent,i,j; for(i=0;i<num;i++) { cd.start=num-1;第12
頁(yè)系統(tǒng)各部分詳細(xì)設(shè)計(jì)及實(shí)現(xiàn) cd.weight=ht[i].weight; child=i; parent=ht[child].parent; while(parent!=-1) { if(ht[parent].lchild==child) cd.bit[cd.start]=0; else cd.bit[cd.start]=1;第13
頁(yè)系統(tǒng)各部分詳細(xì)設(shè)計(jì)及實(shí)現(xiàn) cd.start--; child=parent; parent=ht[child].parent; } for(j=cd.start+1;j<num;j++) hc[i].bit[j]=cd.bit[j]; hc[i].start=cd.start; hc[i].weight=cd.weight; hc[i].ch=str[i]; }第14
頁(yè)系統(tǒng)各部分詳細(xì)設(shè)計(jì)及實(shí)現(xiàn)(三)將生成的哈夫曼編碼寫入文件
hfmTree.txt中
fstreamoutput; output.open("hfmTree.txt",ios::out); if(!output) { cout<<"hfmTree.txtcan'topen!"<<endl; abort(); }第15
頁(yè)系統(tǒng)各部分詳細(xì)設(shè)計(jì)及實(shí)現(xiàn) for(i=0;i<num;i++) { output<<hc[i].ch<<""<<hc[i].weight<<""; for(j=hc[i].start+1;j<num;j++) output<<hc[i].bit[j]; output<<endl; } output.close();第16
頁(yè)系統(tǒng)各部分詳細(xì)設(shè)計(jì)及實(shí)現(xiàn)三、對(duì)文件ToBeTran中的正文進(jìn)行編碼,然后將結(jié)果存入文件CodeFile
voidHaffmanCode::encoding() { fstreaminfile,outfile; infile.open("ToBeTran.txt",ios::in); outfile.open("CodeFile.txt",ios::out); if(!infile)
第17
頁(yè)系統(tǒng)各部分詳細(xì)設(shè)計(jì)及實(shí)現(xiàn) { cout<<"ToBeTran.txtcan'topen!"<<endl; abort(); } if(!outfile) { cout<<"CodeFile.txtcan'topen!"<<endl; abort(); }第18
頁(yè)系統(tǒng)各部分詳細(xì)設(shè)計(jì)及實(shí)現(xiàn)inti,j,loc; charch[255]; while(!infile.eof()) { infile.getline(ch,255); i=0; while(ch[i]!='\0') { loc=loct(ch[i]);第19
頁(yè)系統(tǒng)各部分詳細(xì)設(shè)計(jì)及實(shí)現(xiàn) if(loc!=-1) for(j=hc[loc].start+1;j<num;j++) outfile<<hc[loc].bit[j]; i++; } } infile.close(); outfile.close(); }第20
頁(yè)系統(tǒng)各部分詳細(xì)設(shè)計(jì)及實(shí)現(xiàn)四、利用已建好的哈夫曼樹將文件CodeFile中的代碼進(jìn)行譯碼,將結(jié)果存入TextFile中
voidHaffmanCode::decoding() { fstreaminfile,outfile; infile.open("CodeFile.txt",ios::in); outfile.open("TextFile.txt",ios::out); if(!infile) {
cout<<"CodeFile.txtcan'topen!"<<endl;
abort();第21
頁(yè)系統(tǒng)各部分詳細(xì)設(shè)計(jì)及實(shí)現(xiàn) } if(!outfile) cout<<"TextFile.txtcan'topen!"<<endl; abort(); } inti,j; charch[255]; memset(ch,'5',255); while(!infile.eof()) {第22
頁(yè)系統(tǒng)各部分詳細(xì)設(shè)計(jì)及實(shí)現(xiàn) infile.getline(ch,255); i=0; while(ch[i]!='\0') {
j=2*num-2; while(ht[j].lchild!=-1) { if(ch[i]=='1') j=ht[j].rchild; else j=ht[j].lchild;第23
頁(yè)系統(tǒng)各部分詳細(xì)設(shè)計(jì)及實(shí)現(xiàn)
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝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ì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 2024年度單位員工安全責(zé)任與應(yīng)急管理服務(wù)合同3篇
- 工程委托檢測(cè)協(xié)議
- 2024年單位零星維修施工合同模板下載3篇
- 新時(shí)代好少年簡(jiǎn)短事跡(7篇)
- 校園管理系統(tǒng) 課程設(shè)計(jì)
- 玻璃鋼井蓋課程設(shè)計(jì)
- 心理健康講座活動(dòng)總結(jié)范文(10篇)
- 2025年山東淄博市淄川區(qū)“服務(wù)基層人才專項(xiàng)”招募290管理單位筆試遴選500模擬題附帶答案詳解
- 2025年山東濟(jì)寧市事業(yè)單位招聘考試(市屬+各縣區(qū))管理單位筆試遴選500模擬題附帶答案詳解
- 2025年山東濟(jì)南市長(zhǎng)清區(qū)教育和體育局引進(jìn)緊缺(骨干)教師10人歷年管理單位筆試遴選500模擬題附帶答案詳解
- (完整版)ECRS培訓(xùn)課件
- 《激光原理》復(fù)習(xí)解析
- 增值稅發(fā)票稅控系統(tǒng)專用設(shè)備注銷發(fā)行登記表
- 質(zhì)量管理體系各條款的審核重點(diǎn)
- 聚丙烯化學(xué)品安全技術(shù)說明書(MSDS)
- 蔬菜采購(gòu)合同水果蔬菜采購(gòu)合同
- CX-TGK01C型微電腦時(shí)間溫度控制開關(guān)使用說明書
- 《八年級(jí)下學(xué)期語文教學(xué)個(gè)人工作總結(jié)》
- 電儀工段工段長(zhǎng)職位說明書
- 簡(jiǎn)易送貨單EXCEL打印模板
- 4s店信息員崗位工作職責(zé)
評(píng)論
0/150
提交評(píng)論