數(shù)據(jù)結(jié)構(gòu)課程設(shè)計報告---前綴編碼問題_第1頁
已閱讀1頁,還剩9頁未讀 繼續(xù)免費閱讀

下載本文檔

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

文檔簡介

1、<p>  數(shù) 據(jù) 結(jié) 構(gòu)</p><p><b>  課程設(shè)計報告</b></p><p>  題 目: </p><p>  專 業(yè): </p><p>  班 級:

2、 </p><p>  學(xué) 號: </p><p>  姓 名: </p><p>  指導(dǎo)老師: </p>&

3、lt;p>  時 間: </p><p>  一、課程設(shè)計題目及所涉及知識點</p><p>  設(shè)計題目是:“前綴編碼問題”。</p><p>  所涉及的知識點主要是:</p><p>  本課程設(shè)計利用二叉樹來設(shè)計二進(jìn)制的前綴編碼,前綴編碼顧名思義就是任意一字符的編碼

4、都不是另一個字符的編碼的前綴,主要難點在于如何根據(jù)輸入的字符和使用頻度構(gòu)造出最優(yōu)二叉樹,并根據(jù)構(gòu)造的最優(yōu)二叉樹輸出每個字符的編碼,這主要設(shè)計到對每個字符的權(quán)值進(jìn)行冒泡排序找出最小的兩個權(quán)值作為左右孩子結(jié)點,以他們的和作為父母結(jié)點,并把父母結(jié)點作為新的權(quán)值數(shù)重新排序,最終構(gòu)造出完整的哈夫曼樹,以根的左右路徑分別代表值“0”與“1”連續(xù)存儲,得到每個字符的編碼。</p><p>  二、課程設(shè)計思路及算法描述<

5、/p><p>  設(shè)計思路:通過構(gòu)造哈夫曼樹的結(jié)構(gòu)體定義一個哈夫曼樹組,對用戶輸入的字符以及使用頻率進(jìn)行存儲和初始化,然后對字符進(jìn)行編譯處理,通過構(gòu)造哈夫曼樹編譯出每個字符的編碼,然后對每個編碼進(jìn)行存儲并與字符相關(guān)聯(lián),并輸出每個字符以及對應(yīng)的編碼。最終根據(jù)用戶選擇的功能進(jìn)行編碼和譯碼操作。</p><p>  問題一:哈夫曼樹的表示。</p><p>  設(shè)計哈夫曼樹的

6、結(jié)構(gòu)體,其中包含使用頻率(權(quán)重)、左孩子、右孩子、雙親和要編碼的字符。用這個結(jié)構(gòu)體定義個一個哈夫曼數(shù)組。</p><p>  哈夫曼結(jié)構(gòu)體定義如下:</p><p>  typedef struct</p><p><b>  {</b></p><p>  int weight;</p><p>

7、;  int lchild;</p><p>  int rchild;</p><p>  int parent;</p><p><b>  char key;</b></p><p><b>  }htnode;</b></p><p>  typedef htnode

8、 hfmt[MAXLEN];</p><p>  問題二:對輸入字符進(jìn)行編碼。</p><p>  初始化哈夫曼樹,每個節(jié)點的孩子及雙親默認(rèn)值為-1,使用頻率為0。根據(jù)用戶選擇輸入字符個數(shù)n,以及n個字符和n個權(quán)值,構(gòu)造出哈夫曼樹,并顯示出每個字符及對應(yīng)編碼。</p><p>  1.void creathfmt(hfmt t)//創(chuàng)建哈夫曼樹的函數(shù)</p&g

9、t;<p>  2.void selectmin(hfmt t,int i,int *p1,int *p2)//選出兩個最小的字符權(quán)值</p><p>  3.void phfmnode(hfmt t)//對字符進(jìn)行初始編碼</p><p>  問題三:對用戶輸入的電文進(jìn)行編碼。</p><p>  用戶輸入一連串原本輸入的字符構(gòu)成電文,電文長度在10

10、00字符以內(nèi),由程序進(jìn)行編碼轉(zhuǎn)換。并輸出轉(zhuǎn)換后的編碼。</p><p>  void encoding(hfmt t)//對用戶輸入的電文進(jìn)行編碼 </p><p><b>  { </b></p><p>  char r[1000];//用來存儲輸入的字符串 </p><p><b>  int i,j;&

11、lt;/b></p><p>  printf("\n請輸入需要編碼的字符:");</p><p><b>  gets(r);</b></p><p>  printf("編碼結(jié)果為:"); </p><p>  for(j=0;r[j]!='\0';j++

12、)</p><p>  for(i=0;i<n;i++)</p><p>  if(r[j]==t[i].key)</p><p>  hfmtpath(t,i,j); </p><p>  printf("\n");</p><p><b>  }</b></p&

13、gt;<p>  問題四:對用戶輸入的密文進(jìn)行譯碼。</p><p>  用戶輸入一連串二進(jìn)制代碼字符構(gòu)成密文,電文長度在100個二進(jìn)制代碼以內(nèi),由程序進(jìn)行編碼轉(zhuǎn)換。并輸出轉(zhuǎn)換后的譯碼。</p><p>  void decoding(hfmt t)//對用戶輸入的密文進(jìn)行譯碼</p><p><b>  {</b></p&

14、gt;<p>  char r[100];</p><p>  int i,j,len;</p><p>  j=2*n-2;//j初始從樹的根節(jié)點開始</p><p>  printf("\n請輸入需要譯碼的字符串:");</p><p><b>  gets(r);</b></

15、p><p>  len=strlen(r);</p><p>  printf("譯碼的結(jié)果是:");</p><p>  for(i=0;i<len;i++)</p><p><b>  {</b></p><p>  if(r[i]=='0')</p

16、><p><b>  {</b></p><p>  j=t[j].lchild;</p><p>  if(t[j].lchild==-1)</p><p><b>  {</b></p><p>  printf("%c",t[j].key);</p

17、><p><b>  j=2*n-2;</b></p><p><b>  }</b></p><p><b>  }</b></p><p>  else if(r[i]=='1')</p><p><b>  {</b&g

18、t;</p><p>  j=t[j].rchild;</p><p>  if(t[j].rchild==-1)</p><p><b>  {</b></p><p>  printf("%c",t[j].key);</p><p><b>  j=2*n-2;&

19、lt;/b></p><p><b>  }</b></p><p><b>  }</b></p><p><b>  }</b></p><p>  printf("\n");</p><p><b>  }<

20、;/b></p><p>  三、課程設(shè)計中遇到的難點及解決辦法</p><p>  在程序設(shè)計中遇到的問題主要是如何根據(jù)輸入的字符頻率構(gòu)造哈夫曼樹,這其中涉及到對哈夫曼樹的存儲,以及根據(jù)樹的左孩子路徑為“0”右孩子路徑“1”對字符進(jìn)行二級制編碼,在參考課文和網(wǎng)絡(luò)資源后進(jìn)行整理和加工,設(shè)計出了構(gòu)造哈夫曼樹的程序。由于事先不知道用戶要輸入幾個字符,所以無法判斷最終二進(jìn)制編碼的長度,通過

21、定義一個比較大的存儲空間存儲編碼。在對每個字符構(gòu)造出編碼后根據(jù)用戶選擇進(jìn)行編碼和譯碼,這其中遇到的難點主要是根據(jù)用戶輸入的信息進(jìn)行翻譯,特別是譯碼過程,主要難點的解決時上網(wǎng)百度和詢問老師解決的。</p><p><b>  總結(jié)</b></p><p>  通過這次課程設(shè)計,我對前綴編碼問題有了深刻的認(rèn)識,對哈夫曼樹的優(yōu)越性也有了深刻的了解,利用哈夫曼編碼可以極大的縮

22、短編碼長度,提高信息的傳輸時間,在社會的實際應(yīng)用時很廣泛的,同時通過程序設(shè)計中對哈夫曼樹的構(gòu)造,對我的編程思想有了很大的提高,我對數(shù)據(jù)結(jié)構(gòu)也有了更好的掌握,雖然距離完全的掌握每一個功能操作還有一定的差距,但是我相信通過不斷地學(xué)習(xí)和努力,我一定能做的更好更完善。</p><p>  附錄—主要源程序代碼及運行結(jié)果</p><p>  #include <stdio.h></

23、p><p>  #include <stdlib.h></p><p>  #include <string.h></p><p>  #define MAXLEN 100</p><p>  typedef struct</p><p><b>  {</b></p&

24、gt;<p>  int weight;</p><p>  int lchild;</p><p>  int rchild;</p><p>  int parent;</p><p><b>  char key;</b></p><p><b>  }htnode;

25、</b></p><p>  typedef htnode hfmt[MAXLEN];</p><p><b>  int n;</b></p><p>  void selectmin(hfmt t,int i,int *p1,int *p2)//選中兩個權(quán)值最小的函數(shù) </p><p><b>

26、  {</b></p><p>  long min1=999999;</p><p>  long min2=999999;</p><p><b>  int j;</b></p><p>  for(j=0;j<=i;j++)//選擇最小權(quán)值字符的下標(biāo)返回 </p><p>

27、;  if(t[j].parent==-1)</p><p>  if(min1>t[j].weight)</p><p><b>  {</b></p><p>  min1=t[j].weight;</p><p><b>  *p1=j;</b></p><p>

28、<b>  }</b></p><p>  for(j=0;j<=i;j++)//選擇次小權(quán)值字符的下標(biāo)還回</p><p>  if(t[j].parent==-1)</p><p>  if(min2>t[j].weight&&j!=(*p1))</p><p><b>  {&

29、lt;/b></p><p>  min2=t[j].weight;</p><p><b>  *p2=j;</b></p><p><b>  }</b></p><p><b>  }</b></p><p>  void creathfmt

30、(hfmt t)//創(chuàng)建哈夫曼樹的函數(shù) </p><p><b>  {</b></p><p>  int i,w,p1,p2;</p><p>  char k;//k表示獲取的字符</p><p>  printf("\n");</p><p>  printf(&quo

31、t;------------------------------------------------\n");</p><p>  printf("*********************輸入?yún)^(qū)*********************\n");</p><p>  printf("\n請輸入字符個數(shù):");</p><

32、;p>  scanf("%d",&n);</p><p>  getchar();</p><p>  for(i=0;i<2*n-1;i++)//對結(jié)構(gòu)體進(jìn)行初始化 </p><p><b>  {</b></p><p>  t[i].weight=0;</p>

33、<p>  t[i].lchild=-1;</p><p>  t[i].rchild=-1;</p><p>  t[i].parent=-1;</p><p><b>  }</b></p><p>  printf("\n");</p><p>  for(i=

34、0;i<n;i++)</p><p><b>  {</b></p><p>  printf("請輸入第%d個字符:",i+1);</p><p>  scanf("%c",&k);</p><p>  getchar();</p><p>

35、  t[i].key=k;</p><p>  printf("請輸入第%d個字符的權(quán)值:",i+1);</p><p>  scanf("%d",&w);</p><p>  getchar();</p><p>  t[i].weight=w;</p><p>  p

36、rintf("\n");</p><p><b>  } </b></p><p>  for(i=n;i<2*n-1;i++)</p><p><b>  {</b></p><p>  selectmin(t,i-1,&p1,&p2);</p>

37、;<p>  t[p1].parent=i;</p><p>  t[p2].parent=i;</p><p>  t[i].lchild=p1;</p><p>  t[i].rchild=p2;</p><p>  t[i].weight=t[p1].weight+t[p2].weight; </p><

38、;p><b>  }</b></p><p><b>  }</b></p><p>  void hfmtpath(hfmt t,int i,int j)//編碼的重要哈夫曼樹路徑遞歸算法 </p><p><b>  {</b></p><p><b>  

39、int a,b;</b></p><p><b>  a=i;</b></p><p>  b=j=t[i].parent;</p><p>  if(t[j].parent!=-1) </p><p><b>  {</b></p><p><b> 

40、 i=j;</b></p><p>  hfmtpath(t,i,j);</p><p><b>  }</b></p><p>  if(t[b].lchild==a)</p><p>  printf("0");</p><p><b>  else&

41、lt;/b></p><p>  printf("1");</p><p><b>  }</b></p><p>  void phfmnode(hfmt t)//對字符進(jìn)行初始編碼</p><p><b>  {</b></p><p><

42、b>  int i,j;</b></p><p>  printf("------------------------------------------------\n");</p><p>  printf("*******************哈夫曼編碼*******************\n");</p>

43、<p>  for(i=0;i<n;i++)</p><p><b>  {</b></p><p><b>  j=0;</b></p><p>  printf("\n");</p><p>  printf("\t\t%c\t\t",t[

44、i].key,t[i].weight);</p><p>  hfmtpath(t,i,j);</p><p><b>  }</b></p><p><b>  }</b></p><p>  void encoding(hfmt t)//對用戶輸入的電文進(jìn)行編碼 </p><

45、p><b>  { </b></p><p>  char r[1000];//用來存儲輸入的字符串 </p><p><b>  int i,j;</b></p><p>  printf("\n請輸入需要編碼的字符:");</p><p><b>  gets

46、(r);</b></p><p>  printf("編碼結(jié)果為:"); </p><p>  for(j=0;r[j]!='\0';j++)</p><p>  for(i=0;i<n;i++)</p><p>  if(r[j]==t[i].key)</p><p&

47、gt;  hfmtpath(t,i,j); </p><p>  printf("\n");</p><p><b>  }</b></p><p>  void decoding(hfmt t)//對用戶輸入的密文進(jìn)行譯碼</p><p><b>  {</b></p&g

48、t;<p>  char r[100];</p><p>  int i,j,len;</p><p>  j=2*n-2;//j初始從樹的根節(jié)點開始</p><p>  printf("\n請輸入需要譯碼的字符串:");</p><p><b>  gets(r);</b></p

49、><p>  len=strlen(r);</p><p>  printf("譯碼的結(jié)果是:");</p><p>  for(i=0;i<len;i++)</p><p><b>  {</b></p><p>  if(r[i]=='0')</p&

50、gt;<p><b>  {</b></p><p>  j=t[j].lchild;</p><p>  if(t[j].lchild==-1)</p><p><b>  {</b></p><p>  printf("%c",t[j].key);</p&

51、gt;<p><b>  j=2*n-2;</b></p><p><b>  }</b></p><p><b>  }</b></p><p>  else if(r[i]=='1')</p><p><b>  {</b>

52、;</p><p>  j=t[j].rchild;</p><p>  if(t[j].rchild==-1)</p><p><b>  {</b></p><p>  printf("%c",t[j].key);</p><p><b>  j=2*n-2;&l

53、t;/b></p><p><b>  }</b></p><p><b>  }</b></p><p><b>  }</b></p><p>  printf("\n");</p><p><b>  }<

54、/b></p><p>  void main()</p><p><b>  {</b></p><p><b>  hfmt ht;</b></p><p>  char flag;</p><p>  printf("------------------

55、------------------------------\n");</p><p>  printf(" **********說明********** \n"); </p><p>  printf(" * 11級數(shù)據(jù)結(jié)構(gòu)課程設(shè)計 * \n");</p><p>  pri

56、ntf(" * 哈夫曼編碼 * \n");</p><p>  printf(" * 科學(xué)與技術(shù)專業(yè) 邵帥 * \n");</p><p>  printf(" ************************ \n"); </p>&

57、lt;p>  creathfmt(ht);//創(chuàng)建哈夫曼樹的函數(shù)</p><p>  phfmnode(ht); //對字符進(jìn)行初始編碼 </p><p>  printf("\n------------------------------------------------\n");</p><p><b>  do{</

58、b></p><p>  printf("********************功能選擇********************\n");</p><p>  printf("【1】編碼\t【2】譯碼\t【0】退出\n");</p><p>  printf("您的選擇:");</p>

59、<p>  flag=getchar();</p><p>  getchar();</p><p>  if(flag=='1')</p><p>  encoding(ht);</p><p>  else if(flag=='2')</p><p>  decoding

60、(ht);</p><p>  else if(flag=='0')</p><p><b>  return;</b></p><p><b>  else</b></p><p>  printf("您的輸入有誤,請重新輸入。\n"); </p>

61、<p>  }while(flag!='0');</p><p>  printf("\n");</p><p><b>  }</b></p><p><b>  運行結(jié)果:</b></p><p>  六、指導(dǎo)老師評語及成績</p>

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 眾賞文庫僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
  • 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

最新文檔

評論

0/150

提交評論