![數(shù)據(jù)結(jié)構(gòu)實(shí)驗(yàn)四 -哈夫曼數(shù)與哈弗曼編碼_第1頁](http://file4.renrendoc.com/view10/M02/0C/3F/wKhkGWXQEMiAUXYzAAI5Y6vgmmE903.jpg)
![數(shù)據(jù)結(jié)構(gòu)實(shí)驗(yàn)四 -哈夫曼數(shù)與哈弗曼編碼_第2頁](http://file4.renrendoc.com/view10/M02/0C/3F/wKhkGWXQEMiAUXYzAAI5Y6vgmmE9032.jpg)
![數(shù)據(jù)結(jié)構(gòu)實(shí)驗(yàn)四 -哈夫曼數(shù)與哈弗曼編碼_第3頁](http://file4.renrendoc.com/view10/M02/0C/3F/wKhkGWXQEMiAUXYzAAI5Y6vgmmE9033.jpg)
![數(shù)據(jù)結(jié)構(gòu)實(shí)驗(yàn)四 -哈夫曼數(shù)與哈弗曼編碼_第4頁](http://file4.renrendoc.com/view10/M02/0C/3F/wKhkGWXQEMiAUXYzAAI5Y6vgmmE9034.jpg)
![數(shù)據(jù)結(jié)構(gòu)實(shí)驗(yàn)四 -哈夫曼數(shù)與哈弗曼編碼_第5頁](http://file4.renrendoc.com/view10/M02/0C/3F/wKhkGWXQEMiAUXYzAAI5Y6vgmmE9035.jpg)
版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡(jiǎn)介
第2頁共7頁實(shí)驗(yàn)四哈夫曼樹及其的應(yīng)用一、實(shí)驗(yàn)?zāi)康?、在二叉樹基本操作的基礎(chǔ)上,掌握對(duì)二叉樹的一些其它操作的具體實(shí)現(xiàn)方法。2、掌握構(gòu)造哈夫曼樹以及哈夫曼編碼的方法。3、熟練掌握哈夫曼樹特征及其應(yīng)用二、實(shí)驗(yàn)內(nèi)容題目哈夫曼樹和哈夫曼編碼:從終端輸入若干個(gè)字符,統(tǒng)計(jì)(或指定)字符出現(xiàn)的頻率,將字符出現(xiàn)的頻率作為結(jié)點(diǎn)的權(quán)值,建立哈夫曼樹,然后對(duì)各字符進(jìn)行哈夫曼編碼。最后打印哈夫曼樹和對(duì)應(yīng)的哈夫曼編碼。三、實(shí)驗(yàn)步驟(一)、數(shù)據(jù)結(jié)構(gòu)與核心算法的設(shè)計(jì)描述本實(shí)驗(yàn)在二叉樹基本操作的基礎(chǔ)上著重對(duì)其應(yīng)用,哈弗曼樹及哈弗曼編碼均采用動(dòng)態(tài)數(shù)組存儲(chǔ),關(guān)鍵在于哈弗曼樹的構(gòu)造和哈弗曼編碼,此外對(duì)終端字符的統(tǒng)計(jì)也比較重要。以下是頭文件中數(shù)據(jù)結(jié)構(gòu)的設(shè)計(jì)和相關(guān)函數(shù)的聲明:#defineDataTypechar#include<iostream.h>#include<malloc.h>#include<string.h>#include<iomanip.h>typedefstruct{DataTypech;intweight;//權(quán)值及頻率intparent,lchild,rchild;}HTNode,*HuffmanTree;typedefchar**HuffmanCode;int*TongjiChar(int*text);/*統(tǒng)計(jì)字符出現(xiàn)的頻率*/voidHuffmanCoding(HuffmanTree&HT,HuffmanCode&HC,int*w,intn);//該函數(shù)包含哈弗曼數(shù)的構(gòu)造及哈弗曼編碼voidSelect(HuffmanTreeHT,inti,int&s1,int&s2);voidTranslate(HuffmanTree&HT,HuffmanCode&HC,int&n);(二)、函數(shù)調(diào)用及主函數(shù)設(shè)計(jì)externintn;//n為節(jié)點(diǎn)的個(gè)數(shù)voidmain(){ HuffmanTreeHT; HuffmanCodeHC;int*text,*count;count=TongjiChar(text);HuffmanCoding(HT,HC,count,n); Translate(HT,HC,n);}(三)、程序運(yùn)行結(jié)果分析:(四)、實(shí)驗(yàn)總結(jié)由于有二叉樹的基本操作的經(jīng)驗(yàn),在本實(shí)驗(yàn)中哈弗曼樹的構(gòu)造及哈弗曼編碼相對(duì)就較容易實(shí)現(xiàn),但是本實(shí)驗(yàn)的關(guān)鍵仍在于哈弗曼樹的構(gòu)造和哈弗曼編碼,本實(shí)驗(yàn)的一個(gè)特點(diǎn)是在實(shí)驗(yàn)基本要求的基礎(chǔ)上增加了翻譯功能。盡管實(shí)驗(yàn)過程中不同模塊遇到了不同程度的困難,但是經(jīng)過詳細(xì)的設(shè)計(jì)和反復(fù)的測(cè)試、調(diào)試,實(shí)驗(yàn)最終結(jié)果達(dá)到了實(shí)驗(yàn)的預(yù)期結(jié)果。四、主要算法流程圖及程序清單1、主要算法流程圖:終端輸入字符終端輸入字符統(tǒng)計(jì)字符的頻率構(gòu)造哈弗曼和哈弗曼編碼翻譯結(jié)束2、程序清單統(tǒng)計(jì)字符的頻率模塊:intn=0;int*TongjiChar(int*text){ charch; inti; charstr[100]; intcount[100]; for(i=0;i<100;i++) count[i]=1; inttotal=0; intlength=0; cout<<"請(qǐng)輸入一串字符(以#結(jié)尾):"; do {loop:cin>>ch;length++; total++; if(ch!='#') { str[length-1]=ch; for(i=0;i<length;i++) { if(length!=1) { for(intj=0;j<length-1;j++) { if(str[j]==ch) {count[j]++;length--; gotoloop; } } } } } }while(ch!='#'); length--;//去掉最后一個(gè)#號(hào) total--; cout<<"所有字符的個(gè)數(shù)為(不含#):"<<total<<endl; cout<<"不同字符的個(gè)數(shù)為:"<<length<<endl; text=count;for(i=0;i<length;i++) cout<<str[i]<<""<<"頻率:"<<count[i]<<""<<endl;n=length; returntext;}構(gòu)造哈弗曼數(shù)和哈弗曼編碼模塊:voidHuffmanCoding(HuffmanTree&HT,HuffmanCode&HC,int*w,intn){intm,i,s1,s2,start,c,f;intdata[30];charstr;HuffmanTreep;if(n<=1) return;m=2*n-1;HT=(HuffmanTree)malloc((m+1)*sizeof(HTNode));cout<<"請(qǐng)依次輸入各個(gè)結(jié)點(diǎn)的數(shù)值(可以是字符):\例如:afhkr8680ds\n"; for(i=1;i<=n;i++){cin>>str; data[i]=str; } data[i+1]='\0';for(p=HT+1,i=1;i<=n;++i) { p->weight=*w; str=data[i]; p->ch=str; cout<<"第"<<i<<"個(gè)接點(diǎn)的數(shù)值為:"<<p->ch<<'\n'; p->parent=0; p->lchild=0; p->rchild=0; p++; w++;}for(;i<=m;++i,++p) { p->weight=0;p->parent=0; p->lchild=0; p->rchild=0;}cout<<endl<<"建立哈夫曼樹:";for(i=n+1;i<=m;++i){ Select(HT,i-1,s1,s2); //選擇各元素中權(quán)值最小的兩個(gè)HT[s1].parent=i;HT[s2].parent=i;HT[i].lchild=s1;HT[i].rchild=s2;HT[i].weight=HT[s1].weight+HT[s2].weight;cout<<endl<<setw(6)<<"HT["<<s1<<"]和HT["<<s2<<"]"<<setw(5)<<"生成";cout<<setw(5)<<"HT["<<i<<"],且權(quán)值="<<HT[i].weight<<"的接點(diǎn)。";}HC=(HuffmanCode)malloc((n+1)*sizeof(char*));//哈夫曼編碼char*cd;cd=(char*)malloc(n*sizeof(char));cd[n-1]='\0';cout<<endl<<"哈夫曼編碼如下:"<<endl;for(i=1;i<=n;++i){ start=n-1;for(c=i,f=HT[i].parent;f!=0;c=f,f=HT[f].parent) if(HT[f].lchild==c) cd[--start]='0';//--后的值作為表達(dá)式的值。如果是左支,記為0;右支,記為1; else cd[--start]='1';HC[i]=(char*)malloc((n-start)*sizeof(char));strcpy(HC[i],&cd[start]); cout<<"HT["<<i<<"]"<<"的哈夫曼編碼為:"<<HC[i]<<endl;}free(cd);}//HuffmanCoding()end選澤模塊:voidSelect(HuffmanTreeHT,inti,int&s1,int&s2){ intj,k=1;//j為循環(huán)變量while(HT[k].parent!=0)k++;s1=k;for(j=1;j<=i;j++)if(HT[j].parent==0&&HT[j].weight<HT[s1].weight) s1=j;//s1為權(quán)值最小的元素k=1;while((HT[k].parent!=0||k==s1))k++;s2=k;for(j=1;j<=i;++j)if(HT[j].parent==0&&HT[j].weight<HT[s2].weight&&j!=s1) s2=j;}//Select()end翻譯模塊:voidTranslate(HuffmanTree&HT,HuffmanCode&HC,int&n){inti,k,j=0;HuffmanTreep;char*data;data=newchar[n+1];for(p=HT+1,i=1;i<=n;i++,p++)data[i]=p->ch;cout<<"各結(jié)點(diǎn)數(shù)值依次是:";for(i=1;i<=n;i++) cout<<data[i]<<"";cout<<endl;char*str;str=newchar[n];cout<<"(提示:請(qǐng)您輸入需要譯碼的0和1的個(gè)數(shù)以及序列!例如:6010111)"<<endl;cin>>k;char*ch;ch=newchar[k+1];for(intm=0;m<k;m++) cin>>ch[m];ch[k]='\0';cout<<"翻譯后的字符序列是"; while(ch[j]!='\0') { for(i=1;i<=n;i++) { str[i-1]=ch[j];
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(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ì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 未來十年移動(dòng)支付的科技發(fā)展趨勢(shì)預(yù)測(cè)
- 標(biāo)準(zhǔn)化管理在生產(chǎn)現(xiàn)場(chǎng)的挑戰(zhàn)與對(duì)策
- 現(xiàn)代音樂文化的全球化傳播路徑
- 13人物描寫一組(說課稿)2023-2024學(xué)年統(tǒng)編版語文五年級(jí)下冊(cè)
- Unit 1 Playtime Lesson 3(說課稿)-2023-2024學(xué)年人教新起點(diǎn)版英語二年級(jí)下冊(cè)001
- 25 少年閏土 第二課時(shí) 說課稿-2024-2025學(xué)年語文六年級(jí)上冊(cè) 統(tǒng)編版
- Unit1 London is a big city(說課稿)2023-2024學(xué)年外研版(三起)四年級(jí)下冊(cè)
- 2024-2025學(xué)年高中生物 第七章 現(xiàn)代生物進(jìn)化理論 第1節(jié) 現(xiàn)代生物進(jìn)化理論的由來說課稿3 新人教版必修2
- Unit 2 Being a good language learner Exploring and Using 說課稿-2024-2025學(xué)年高中英語重大版(2019)必修第一冊(cè)
- 2025挖掘機(jī)勞動(dòng)合同范文
- 北師大版五年級(jí)上冊(cè)四則混合運(yùn)算100道及答案
- 專項(xiàng)債券在燃?xì)饣A(chǔ)設(shè)施建設(shè)中的融資作用
- 人教部編版道德與法治八年級(jí)下冊(cè):6.3 《國(guó)家行政機(jī)關(guān)》說課稿1
- GE-LM2500+G4航改燃?xì)廨啓C(jī)在艦船和工業(yè)上的應(yīng)用
- 2024山東能源集團(tuán)中級(jí)人才庫(kù)選拔(高頻重點(diǎn)提升專題訓(xùn)練)共500題附帶答案詳解
- 鋼鐵是怎樣煉成的讀后感作文700字
- 武漢市江夏區(qū)2022-2023學(xué)年七年級(jí)上學(xué)期期末數(shù)學(xué)試卷【帶答案】-109
- 學(xué)校物業(yè)服務(wù)合同范本專業(yè)版
- SL 288-2014 水利工程施工監(jiān)理規(guī)范
- 部編版八年級(jí)語文上冊(cè)期末考試卷
- 2024年02月中央軍委后勤保障部2024年公開招考專業(yè)技能崗位文職人員筆試參考題庫(kù)附帶答案詳解
評(píng)論
0/150
提交評(píng)論