數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)--數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)----huffman編碼_第1頁(yè)
已閱讀1頁(yè),還剩24頁(yè)未讀 繼續(xù)免費(fèi)閱讀

下載本文檔

版權(quán)說(shuō)明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)

文檔簡(jiǎn)介

1、<p><b>  數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)</b></p><p>  題目: Huffman編碼 </p><p>  姓名: </p><p>  班級(jí): </p><p>  學(xué)號(hào): </p><p>  指導(dǎo)老師:

2、 </p><p>  日期: 2013年6月24日 </p><p><b>  前言3</b></p><p><b>  課程設(shè)計(jì)報(bào)告5</b></p><p><b>  一.實(shí)驗(yàn)?zāi)康?</b></p><p>  二.實(shí)驗(yàn)題目:赫夫

3、曼編碼7</p><p><b>  1.問(wèn)題描述7</b></p><p><b>  2.需求分析7</b></p><p><b>  三. 概要設(shè)計(jì)9</b></p><p>  四. 詳細(xì)設(shè)計(jì)11</p><p><b> 

4、 1.設(shè)計(jì)思想11</b></p><p>  五. 測(cè)試分析16</p><p>  六. 使用說(shuō)明18</p><p>  七. 測(cè)試結(jié)果19</p><p><b>  八. 附錄20</b></p><p><b>  1.源代碼20</b>&

5、lt;/p><p><b>  2.運(yùn)行結(jié)果25</b></p><p><b>  前言</b></p><p>  隨著計(jì)算機(jī)的普遍應(yīng)用與日益發(fā)展,其應(yīng)用早已不局限于簡(jiǎn)單的數(shù)值運(yùn)算,而涉及到問(wèn)題的分析、數(shù)據(jù)結(jié)構(gòu)框架的設(shè)計(jì)以及設(shè)計(jì)最短路線等復(fù)雜的非數(shù)值處理和操作。算法與數(shù)據(jù)結(jié)構(gòu)的學(xué)習(xí)就是為以后利用計(jì)算機(jī)資源高效地開(kāi)發(fā)非數(shù)值

6、處理的計(jì)算機(jī)程序打下堅(jiān)實(shí)的理論、方法和技術(shù)基礎(chǔ)。</p><p>  算法與數(shù)據(jù)結(jié)構(gòu)旨在分析研究計(jì)算機(jī)加工的數(shù)據(jù)對(duì)象的特性,以便選擇適當(dāng)?shù)臄?shù)據(jù)結(jié)構(gòu)和存儲(chǔ)結(jié)構(gòu),從而使建立在其上的解決問(wèn)題的算法達(dá)到最優(yōu)。</p><p>  數(shù)據(jù)結(jié)構(gòu)是在整個(gè)計(jì)算機(jī)科學(xué)與技術(shù)領(lǐng)域上廣泛被使用的術(shù)語(yǔ)。它用來(lái)反映一個(gè)數(shù)據(jù)的內(nèi)部構(gòu)成,即一個(gè)數(shù)據(jù)由那些成分?jǐn)?shù)據(jù)構(gòu)成,以什么方式構(gòu)成,呈什么結(jié)構(gòu)。數(shù)據(jù)結(jié)構(gòu)有邏輯上的數(shù)據(jù)結(jié)構(gòu)

7、和物理上的數(shù)據(jù)結(jié)構(gòu)之分。邏輯上的數(shù)據(jù)結(jié)構(gòu)反映成分?jǐn)?shù)據(jù)之間的邏輯關(guān)系,而物理上的數(shù)據(jù)結(jié)構(gòu)反映成分?jǐn)?shù)據(jù)在計(jì)算機(jī)內(nèi)部的存儲(chǔ)安排。數(shù)據(jù)結(jié)構(gòu)是數(shù)據(jù)存在的形式。</p><p>  《數(shù)據(jù)結(jié)構(gòu)》主要介紹一些最常用的數(shù)據(jù)結(jié)構(gòu),闡明各種數(shù)據(jù)結(jié)構(gòu)內(nèi)在的邏輯關(guān)系,討論其在計(jì)算機(jī)中的存儲(chǔ)表示,以及在其上進(jìn)行各種運(yùn)算時(shí)的實(shí)現(xiàn)算法,并對(duì)算法的效率進(jìn)行簡(jiǎn)單的分析和討論。數(shù)據(jù)結(jié)構(gòu)是介于數(shù)學(xué)、計(jì)算機(jī)軟件和計(jì)算機(jī)硬件之間的一門計(jì)算機(jī)專業(yè)的核心課程

8、,它是計(jì)算機(jī)程序設(shè)計(jì)、數(shù)據(jù)庫(kù)、操作系統(tǒng)、編譯原理及人工智能等的重要基礎(chǔ),廣泛的應(yīng)用于信息學(xué)、系統(tǒng)工程等各種領(lǐng)域。</p><p>  學(xué)習(xí)數(shù)據(jù)結(jié)構(gòu)是為了將實(shí)際問(wèn)題中所涉及的對(duì)象在計(jì)算機(jī)中表示出來(lái)并對(duì)它們進(jìn)行處理。通過(guò)課程設(shè)計(jì)可以提高學(xué)生的思維能力,促進(jìn)學(xué)生的綜合應(yīng)用能力和專業(yè)素質(zhì)的提高。</p><p><b>  課程設(shè)計(jì)報(bào)告</b></p><

9、p><b>  一.實(shí)驗(yàn)?zāi)康?lt;/b></p><p>  數(shù)據(jù)結(jié)構(gòu)作為一門學(xué)科主要研究數(shù)據(jù)的各種邏輯結(jié)構(gòu)和存儲(chǔ)結(jié)構(gòu),以及對(duì)數(shù)據(jù)的各種操作。因此,主要有三個(gè)方面的內(nèi)容:數(shù)據(jù)的邏輯結(jié)構(gòu);數(shù)據(jù)的物理存儲(chǔ)結(jié)構(gòu);對(duì)數(shù)據(jù)的操作(或算法)。通常,算法的設(shè)計(jì)取決于數(shù)據(jù)的邏輯結(jié)構(gòu),算法的實(shí)現(xiàn)取決于數(shù)據(jù)的物理存儲(chǔ)結(jié)構(gòu)。數(shù)據(jù)結(jié)構(gòu)是信息的一種組織方式,其目的是為了提高算法的效率,它通常與一組算法的集合相對(duì)應(yīng),

10、通過(guò)這組算法集合可以對(duì)數(shù)據(jù)結(jié)構(gòu)中的數(shù)據(jù)進(jìn)行某種操作。</p><p>  數(shù)據(jù)結(jié)構(gòu)課程主要是研究非數(shù)值計(jì)算的程序設(shè)計(jì)問(wèn)題中所出現(xiàn)的計(jì)算機(jī)操作對(duì)象以及它們之間的關(guān)系和操作的學(xué)科。數(shù)據(jù)結(jié)構(gòu)是介于數(shù)學(xué)、計(jì)算機(jī)軟件和計(jì)算機(jī)硬件之間的一門計(jì)算機(jī)專業(yè)的核心課程,它是計(jì)算機(jī)程序設(shè)計(jì)、數(shù)據(jù)庫(kù)、操作系統(tǒng)、編譯原理及人工智能等的重要基礎(chǔ),廣泛的應(yīng)用于信息學(xué)、系統(tǒng)工程等各種領(lǐng)域。</p><p>  學(xué)習(xí)數(shù)據(jù)結(jié)

11、構(gòu)是為了將實(shí)際問(wèn)題中所涉及的對(duì)象在計(jì)算機(jī)中表示出來(lái)并對(duì)它們進(jìn)行處理。通過(guò)課程設(shè)計(jì)可以提高學(xué)生的思維能力,促進(jìn)學(xué)生的綜合應(yīng)用能力和專業(yè)素質(zhì)的提高。通過(guò)此次課程設(shè)計(jì)主要達(dá)到以下目的:</p><p>  1、了解并掌握數(shù)據(jù)結(jié)構(gòu)與算法的設(shè)計(jì)方法,具備初步的獨(dú)立分析和設(shè)計(jì)能力;</p><p>  2、初步掌握軟件開(kāi)發(fā)過(guò)程的問(wèn)題分析、系統(tǒng)設(shè)計(jì)、程序編碼、測(cè)試等基本方法和技能;</p>

12、<p>  3、提高綜合運(yùn)用所學(xué)的理論知識(shí)和方法獨(dú)立分析和解決問(wèn)題的能力;</p><p>  4、訓(xùn)練用系統(tǒng)的觀點(diǎn)和軟件開(kāi)發(fā)一般規(guī)范進(jìn)行軟件開(kāi)發(fā),培養(yǎng)軟件工作者所應(yīng)具備的科學(xué)的工作方法和作風(fēng)。</p><p>  二.實(shí)驗(yàn)題目:赫夫曼編碼</p><p><b>  1.問(wèn)題描述</b></p><p> 

13、 已知某系統(tǒng)在通信聯(lián)絡(luò)中只可能出現(xiàn)8種字符(a,b,c,d,e,f,g,h),其概率分別是:0.06,0.28,0.07,0.09,0.14,0.21,0.03,0.12</p><p> ?、佥斎?種字符的概率;</p><p><b> ?、跇?gòu)造赫夫曼樹(shù);</b></p><p> ?、圯敵雒總€(gè)字符的赫夫曼編碼;</p>&l

14、t;p><b>  2.需求分析</b></p><p>  赫夫曼編碼的應(yīng)用很廣泛,利用赫夫曼樹(shù)求得的用于通信的二進(jìn)制編碼成為赫夫曼編碼。樹(shù)中從根到 每個(gè)葉子都有一條路徑,對(duì)路徑上的各分支約定:指向左子樹(shù)的分支表示“0”碼,指向右子樹(shù)的分支表示 “1”碼,取每條路徑上的“0”或“1”的序列作為和每個(gè)葉子對(duì)應(yīng)的字符的編碼,這就是赫夫曼編碼。 </p><p> 

15、 通常我們把數(shù)據(jù)壓縮的過(guò)程稱為編碼,解壓縮的過(guò)程稱為解碼。電報(bào)通信是傳遞文字的二進(jìn)制碼形式 的字符串,但在信息傳遞時(shí),總希望總長(zhǎng)度能盡可能短,即采用最短碼。</p><p>  假設(shè)每種字符在電文中出現(xiàn)的次數(shù)為W i ,編碼長(zhǎng)度為L(zhǎng) i ,電文中有n 種字符,則電文編碼總長(zhǎng)為∑W i L i 。 若將此對(duì)應(yīng)到二叉樹(shù)上,W i 為葉節(jié)點(diǎn)的權(quán) ,L i 為根節(jié)點(diǎn)到葉節(jié)點(diǎn)的路徑長(zhǎng)度。那么,∑W i L i 恰好為二叉

16、樹(shù)上帶權(quán)路徑長(zhǎng)度。 </p><p>  因此,設(shè)計(jì)電文總長(zhǎng)最短的二進(jìn)制前綴編碼,就是以n 種子符出現(xiàn)的頻率作權(quán),構(gòu)造一刻赫夫曼樹(shù), 此構(gòu)造過(guò)程成為赫夫曼編碼。 </p><p>  本演示程序用C++6.0編寫,完成赫夫曼樹(shù)的構(gòu)造以及赫夫曼編碼的設(shè)計(jì)。</p><p> ?。?)輸入的形式和輸入值的范圍:n中字符,其出現(xiàn)的頻率</p><p&g

17、t; ?。?) 輸出的形式: 二進(jìn)制前綴編碼</p><p> ?。?) 程序所能達(dá)到的功能:設(shè)計(jì)一顆赫夫曼樹(shù),由此得到二進(jìn)制前綴編碼,即赫夫曼編碼。</p><p><b> ?。?)測(cè)試數(shù)據(jù):</b></p><p>  已知某系統(tǒng)在通信聯(lián)絡(luò)中只可能出現(xiàn)8種字符(a,b,c,d,e,f,g,h),其概率分別是:0.06,0.28,0.07,

18、0.09,0.14,0.21,0.03,0.12</p><p> ?、佥斎?種字符的概率;</p><p><b> ?、跇?gòu)造赫夫曼樹(shù);</b></p><p> ?、圯敵雒總€(gè)字符的赫夫曼編碼;</p><p><b>  三. 概要設(shè)計(jì)</b></p><p> ?。?)

19、為了實(shí)現(xiàn)上述程序功能,需要定義單鏈表的抽象數(shù)據(jù)類型:</p><p>  ADT BinaryTree {</p><p>  數(shù)據(jù)對(duì)象D:D是具有相同特性的數(shù)據(jù)元素的集合。</p><p>  數(shù)據(jù)關(guān)系R: 若D=,則R=,稱BinaryTree為空二叉樹(shù);</p><p><b>  若D,則R={H}</b><

20、;/p><p><b>  基本操作:</b></p><p>  void HuffmanCoding(HuffmanTree&,HuffmanCode&,int)</p><p>  操作結(jié)果:求赫夫曼編碼</p><p>  void Select(HuffmanTree,int,int*,int*)&

21、lt;/p><p>  操作結(jié)果:查找權(quán)值較小的兩個(gè)結(jié)點(diǎn)</p><p>  void OutputHuffmanCode(HuffmanTree,HuffmanCode,int)</p><p>  操作結(jié)果:輸出赫夫曼編碼</p><p> ?。?)本程序包含4個(gè)函數(shù):  ① 主函數(shù)main() ?、?求赫夫曼編碼函數(shù)HuffmanC

22、oding();</p><p> ?、鄄檎覚?quán)值較小的兩個(gè)結(jié)點(diǎn)函數(shù)Select ();  ④ 輸出赫夫曼編碼函數(shù)OutputHuffmanCode ()  </p><p>  各函數(shù)間關(guān)系如下: </p><p>  HuffmanCoding()</p><p>  Main Select ()&l

23、t;/p><p>  OutputHuffmanCode ()</p><p><b>  四. 詳細(xì)設(shè)計(jì)</b></p><p>  實(shí)現(xiàn)概要設(shè)計(jì)中定義的所有的數(shù)據(jù)類型,對(duì)每個(gè)操作給出偽碼算法。對(duì)主程序和其他模塊也都需要寫出偽碼算法。</p><p><b>  1.設(shè)計(jì)思想</b></p>

24、;<p>  哈夫曼編譯碼系統(tǒng)的主要功能是先建立哈夫曼樹(shù),然后利用建好的哈夫曼樹(shù)生成哈夫曼編碼后進(jìn)行譯碼 。 </p><p>  在通信中可以采用0和1的不同排列來(lái)表示不同的字符,稱為二進(jìn)制編碼。而赫夫曼樹(shù)在數(shù)據(jù)編碼中的應(yīng)用是數(shù)據(jù)的最小冗余編碼問(wèn)題他是數(shù)據(jù)壓縮學(xué)的基礎(chǔ)。若每個(gè)字符出現(xiàn)的頻率相同,則可以采用等長(zhǎng)的二進(jìn)制編碼,頻率不同,采用不等長(zhǎng)的二進(jìn)制編碼,頻率達(dá)的字符采用位數(shù)較

25、少的編碼,頻率小的采用位數(shù)較多的編碼。赫夫曼編碼就是一種不等長(zhǎng)的二進(jìn)制編碼,而赫夫曼樹(shù)是一種最優(yōu)二叉樹(shù),它 的編碼也是一種最優(yōu)編碼。在赫夫曼樹(shù)中,規(guī)定往左編碼為0,往右編碼為1,則得到葉子節(jié)點(diǎn)的編碼為從根結(jié)點(diǎn)帶葉子結(jié)點(diǎn)中所有路徑中0和1的順序排列。 </p><p>  設(shè)計(jì)包含的幾個(gè)方面: </p><p>  ① 赫夫曼樹(shù)的構(gòu)造 <

26、;/p><p>  假設(shè)有n個(gè)權(quán)值,則構(gòu)造出的赫夫曼樹(shù)有n個(gè)葉子結(jié)點(diǎn)。n個(gè)權(quán)值分別為w1,w2,………wn,則赫夫曼樹(shù)構(gòu)造規(guī)則為: </p><p>  1、將w1,w2,…….wn,看成有n棵樹(shù)的森林。 </p><p>  2、在森林中選出兩個(gè)根結(jié)點(diǎn)最小的樹(shù)合并,作為一棵新樹(shù)的左右子書,且新樹(shù)根結(jié)點(diǎn)權(quán)值為左右子樹(shù)根結(jié)點(diǎn)權(quán)值之和。 <

27、;/p><p>  3、從森林中刪除選取的兩棵樹(shù),并將新樹(shù)加入森林。 </p><p>  4、重復(fù)2和3步驟,直到森林中只剩一棵樹(shù)為止</p><p><b> ?、?#160;赫夫曼編碼</b></p><p><b> ?。?)結(jié)點(diǎn)類型</b></p><p> 

28、 typedef struct {</p><p>  ElemType elem;</p><p>  unsigned int weight;</p><p>  unsigned int parent,lchild,rchild;</p><p>  } HTNode,*HuffmanTree;//動(dòng)態(tài)分配數(shù)組存儲(chǔ)赫夫曼樹(shù)</

29、p><p>  (2)其他模塊偽碼算法</p><p>  void HuffmanCoding(HuffmanTree&,HuffmanCode&,int)</p><p><b> ?。▊未a算法)</b></p><p>  void Select(HuffmanTree,int,int*,int*)&l

30、t;/p><p><b> ?。▊未a算法)</b></p><p>  void OutputHuffmanCode(HuffmanTree,HuffmanCode,int)  (偽碼算法)</p><p><b>  (3)算法分析設(shè)計(jì)</b></p><p>  void HuffmanCodin

31、g(HuffmanTree&HT,HuffmanCode&HC,int n);</p><p><b>  {</b></p><p>  int i,m,s1,s2,start,c,f;</p><p><b>  char*cd;</b></p><p>  char chl//

32、元素</p><p><b>  if(n<=1)</b></p><p><b>  return;</b></p><p><b>  m=2*n-1;</b></p><p>  HT=new HTNode[m+1];</p><p>  f

33、or(i=1;i<=n;i++)</p><p>  {//初始化前n個(gè)節(jié)點(diǎn)</p><p>  cout<<"輸入元素和所占比例:";</p><p>  cin>>ch>>wei;</p><p>  HT[i].elem=ch;</p><p>  H

34、T[i].weight=wei;</p><p>  HT[i].parent=HT[i].lchild=HT[i]rchild=0;</p><p><b>  }</b></p><p>  for(i=n+1;i<=m;++i)</p><p>  {//初始化后n+1...m</p><

35、p>  HT[i].elem='0';</p><p>  HT[i].weight=HT[i].parent=HT[i]lchild=HT[i].rchild=0;</p><p><b>  }</b></p><p>  for(i=n+1;i<=m;++i)</p><p>  {//

36、生成n+1...m</p><p>  Select(HT,i-1,&s1,&s2);//查找權(quán)值較小的兩個(gè)節(jié)點(diǎn)</p><p>  HT[s1].parent=i;HT[s2]parent=i;</p><p>  HT[i].lchild=s1;HT[i].rchild=s2;</p><p>  HT[i].weight

37、=HT[s1].weight+HT[s2].weight;</p><p><b>  }</b></p><p>  HC=new char*[n+1];</p><p>  cd=new char[n];</p><p>  cd[n-1]='\0';</p><p>  fo

38、r(i=1;i<=m;++i)</p><p>  {//生成HuffmanCode</p><p>  start=n-1;</p><p>  for(c=i;f=HT[i].parent;f!=0;c=f;f=HT[f].parent)</p><p><b>  {</b></p><p

39、>  if(HT[f].child==c)cd[--start]='0';</p><p>  else cd[--start]='1';</p><p><b>  }</b></p><p>  HC[i]=new char[n-start];</p><p>  strcpy(

40、HC[i],&cd[start]);</p><p><b>  }</b></p><p><b>  }</b></p><p><b>  五. 測(cè)試分析</b></p><p>  在我自己課程設(shè)計(jì)中,就在編寫好源代碼后的調(diào)試中出現(xiàn)了不少的錯(cuò)誤,遇到了很多麻煩及

41、困難,我的調(diào)試及其中的錯(cuò)誤和我最終找出錯(cuò)誤,修改為正確的能夠執(zhí)行的程序中,通過(guò)分析,我學(xué)到了:</p><p>  在定義頭文件時(shí)可多不可少,即我們可多寫些頭文件,肯定不會(huì)出錯(cuò),但是若沒(méi)有定義所引用的相關(guān)頭文件,必定調(diào)試不通過(guò);</p><p>  在執(zhí)行譯碼操作時(shí),不知什么原因,總是不能把要編譯的二進(jìn)制數(shù)與編譯成的字符用連接號(hào)連接起來(lái),而是按順序直接放在一起,視覺(jué)效果不是很好。還有就是,

42、很遺憾的是,我們的哈夫曼編碼/譯碼器沒(méi)有像老師要求的那樣完成編一個(gè)文件的功能,這是我們?cè)O(shè)計(jì)的失敗之處。</p><p>  通過(guò)本次數(shù)據(jù)結(jié)構(gòu)的課程設(shè)計(jì),我學(xué)習(xí)了很多在上課沒(méi)懂的知識(shí),并對(duì)求哈夫曼樹(shù)及哈夫曼編碼/譯碼的算法有了更加深刻的了解,更鞏固了課堂中學(xué)習(xí)有關(guān)于哈夫曼編碼的知識(shí),真正學(xué)會(huì)一種算法了。當(dāng)求解一個(gè)算法時(shí),不是拿到問(wèn)題就不加思索地做,而是首先要先對(duì)它有個(gè)大概的了解,接著再詳細(xì)地分析每一步怎么做,無(wú)論自

43、己以前是否有處理過(guò)相似的問(wèn)題,只要按照以上的步驟,必定會(huì)順利地做出來(lái)。</p><p>  這次課程設(shè)計(jì),我在編輯中犯了不應(yīng)有的錯(cuò)誤,設(shè)計(jì)統(tǒng)計(jì)字符和合并時(shí)忘記應(yīng)該怎樣保存數(shù)據(jù),對(duì)文件的操作也很生疏。在不斷分析后明確并改正了錯(cuò)誤和疏漏,我的程序有了更高的質(zhì)量。</p><p><b>  六. 使用說(shuō)明</b></p><p>  1.程序名為k

44、eshe.exe,運(yùn)行環(huán)境為DOS。程序執(zhí)行后顯示:</p><p>  2.輸入要編碼的字符種類數(shù)為8然后程序顯示:</p><p>  3.然后依次輸入8個(gè)字符及出現(xiàn)比例</p><p><b>  七. 測(cè)試結(jié)果</b></p><p>  1.輸入第一個(gè)字符與所占比例:a , 6</p><p

45、>  2. 輸入第一個(gè)字符與所占比例:b, 28</p><p>  3. 輸入第一個(gè)字符與所占比例:c, 7</p><p>  4. 輸入第一個(gè)字符與所占比例:d, 9</p><p>  5. 輸入第一個(gè)字符與所占比例:e, 14</p><p>  6. 輸入第一個(gè)字符與所占比例:f, 21</p><p&g

46、t;  7. 輸入第一個(gè)字符與所占比例:g, 3</p><p>  8. 輸入第一個(gè)字符與所占比例:h, 12</p><p><b>  八. 附錄</b></p><p><b>  1.源代碼</b></p><p>  #include<iostream.h></p>

47、;<p>  #include<stdio.h></p><p>  #include<stdlib.h></p><p>  #include<string.h></p><p>  typedef int Status;</p><p>  typedef char ElemType;&l

48、t;/p><p>  typedef struct</p><p><b>  {</b></p><p>  ElemType elem;</p><p>  unsigned int weight;</p><p>  unsigned int parent,lchild,rchild;<

49、/p><p>  }HTNode,*HuffmanTree;//動(dòng)態(tài)分配數(shù)組存儲(chǔ)赫夫曼樹(shù)</p><p>  typedef char**HuffmanCode;// 動(dòng)態(tài)分配數(shù)組存儲(chǔ)赫夫曼編碼表</p><p>  void HuffmanCoding(HuffmanTree&,HuffmanCode&,int);</p><p&g

50、t;  void Select(HuffmanTree,int,int*,int*);</p><p>  void OutputHuffmanCode(HuffmanTree,HuffmanCode,int);</p><p>  Status main()</p><p><b>  {</b></p><p>  

51、HuffmanTree HT;</p><p>  HuffmanCode HC;</p><p>  int i,n;//the number of elements;</p><p>  cout<<"請(qǐng)輸入要編碼的字符種類數(shù):";</p><p><b>  cin>>n;</

52、b></p><p>  HuffmanCoding(HT,HC,n);</p><p>  OutputHuffmanCode(HT,HC,n);</p><p><b>  return 1;</b></p><p><b>  }</b></p><p>  vo

53、id HuffmanCoding(HuffmanTree&HT,HuffmanCode&HC,int n)</p><p><b>  {</b></p><p>  int i,m,s1,s2,start,c,f;</p><p><b>  char *cd;</b></p><p&

54、gt;  char ch;//元素;</p><p>  int wei;//權(quán)重;</p><p>  if(n<=1)return;</p><p><b>  m=2*n-1;</b></p><p>  HT=new HTNode[m+1];</p><p>  for(i=1;i&

55、lt;=n;++i)</p><p>  {//初始化前n個(gè)結(jié)點(diǎn)</p><p>  cout<<"輸入元素和所占比例:";</p><p>  cin>>ch>>wei;</p><p>  HT[i].elem=ch;</p><p>  HT[i].weig

56、ht=wei;</p><p>  HT[i].parent=HT[i].lchild=HT[i].rchild=0;</p><p><b>  }</b></p><p>  for(i=n+1;i<=m;++i)</p><p>  {//初始化后幾個(gè)結(jié)點(diǎn)n+1...m</p><p>

57、;  HT[i].elem='0';</p><p>  HT[i].parent=HT[i].lchild=HT[i].rchild=0;</p><p><b>  }</b></p><p>  for(i=n+1;i<=m;++i)</p><p>  {//生成n+1...m個(gè)結(jié)點(diǎn);<

58、;/p><p>  Select(HT,i-1,&s1,&s2);//查找權(quán)值較小的兩個(gè)結(jié)點(diǎn)</p><p>  HT[s1].parent=i;HT[s2].parent=i;</p><p>  HT[i].lchild=s1;HT[i].rchild=s2;</p><p>  HT[i].weight=HT[s1].wei

59、ght+HT[s2].weight;</p><p><b>  }</b></p><p>  HC=new char*[n+1];</p><p>  cd=new char[n];</p><p>  cd[n-1]='\0';</p><p>  for(i=1;i<

60、=n;++i)</p><p>  {//生成HuffmanCode</p><p>  start=n-1;</p><p>  for(c=i,f=HT[i].parent;f!=0;c=f,f=HT[f].parent)</p><p>  {if(HT[f].lchild==c)cd[--start]='0';<

61、/p><p>  else cd[--start]='1';</p><p><b>  }</b></p><p>  HC[i]=new char[n-start];</p><p>  strcpy(HC[i],&cd[start]);</p><p><b>

62、  }</b></p><p><b>  }</b></p><p>  void Select(HuffmanTree HT,int n,int *s1,int *s2)</p><p>  {//查找權(quán)值較小的兩個(gè)結(jié)點(diǎn)</p><p><b>  int i;</b></p&

63、gt;<p>  (*s1)=(*s2)=0;</p><p>  for(i=1;i<=n;i++)</p><p>  if(HT[i].weight<HT[(*s2)].weight&&HT[i].parent==0)</p><p>  if(HT[i].weight<HT[(*s1)].weight)<

64、/p><p>  {(*s2)=(*s1);</p><p><b>  (*s1)=i;</b></p><p><b>  }</b></p><p>  else(*s2)=i;</p><p>  if((*s1)>(*s2))</p><p&g

65、t;<b>  {i=(*s1);</b></p><p>  (*s1)=(*s2);</p><p><b>  (*s2)=i;</b></p><p><b>  }</b></p><p><b>  return;</b></p>

66、<p><b>  }</b></p><p>  void OutputHuffmanCode(HuffmanTree HT,HuffmanCode HC,int n)</p><p>  {//輸出 HuffmanCode</p><p><b>  int i;</b></p><p&

67、gt;  cout<<"\nnumber---element---weight---huffman code\n";</p><p>  for(i=1;i<=n;i++)</p><p>  cout<<" "<<i<<" "<<HT[i].e

溫馨提示

  • 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ì)自己和他人造成任何形式的傷害或損失。

評(píng)論

0/150

提交評(píng)論