數(shù)據(jù)結(jié)構(gòu)課程設計---哈夫曼編碼器_第1頁
已閱讀1頁,還剩12頁未讀, 繼續(xù)免費閱讀

下載本文檔

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

文檔簡介

1、<p>  程序設計(大作業(yè))報告</p><p>  課程名稱:數(shù)據(jù)結(jié)構(gòu)課程設計 </p><p>  設計題目:哈夫曼編碼器 </p><p>  院 系:信息技術(shù)學院 </p><p>  班 級:計算機科學與技術(shù)2 班</p><p>  設 計 者:

2、 </p><p>  學 號: </p><p>  指導教師: </p><p>  設計時間:2012.1.9-2012.1.11 </p><p>  課程設計(大作業(yè))任務書</p><p>  課程設計題目:哈夫曼編碼器 &l

3、t;/p><p><b>  課程設計要求:</b></p><p> ?。?)初始化:鍵盤輸入n個字符和n個權(quán)值,建立哈夫曼樹</p><p> ?。?)編碼:利用建好的huffman樹生成huffman編碼</p><p><b> ?。?)輸出編碼</b></p><p>

4、 ?。?)字符和頻度如下:</p><p>  ① 字符:空格 A B C D E F G H I J K L M N O P Q</p><p>  頻度:186 64 13 22 32 103 21 15 47 57 1 2 32 20 57 63 15 1</p><p> ?、?字符:R S T U V W X Y Z</p><p>

5、;  頻度:48 51 80 23 8 18 1 16</p><p><b>  工作計劃及安排</b></p><p> ?。?)在上機之前選題</p><p>  (2)選擇合適的數(shù)據(jù)結(jié)構(gòu)</p><p> ?。?)結(jié)點結(jié)構(gòu)的設計</p><p>  (4)算法設計與分析</p>

6、<p> ?。?)程序設計、實現(xiàn)、調(diào)試</p><p>  (6)提交課程設計報告</p><p>  指導教師簽字 </p><p>  年 月 日 </p><p>  課程設計(大作業(yè))成績</p><p>  學號: 姓名: 指導教師:

7、 老師</p><p>  課程設計題目: 哈夫曼編碼器 </p><p><b>  總結(jié):</b></p><p>  通過此次的課程設計使我認識了哈夫曼樹的建立與應用,復習了數(shù)據(jù)結(jié)構(gòu)中的樹的存儲結(jié)構(gòu),怎樣構(gòu)造哈夫曼樹以及用哈夫曼樹進行編碼。學習數(shù)據(jù)結(jié)構(gòu)能使我們?yōu)槠渌n程打好基礎,而課程設計作為數(shù)據(jù)結(jié)構(gòu)中一個重要環(huán)節(jié)能更好的使我們加深

8、對它的了解。</p><p><b>  指導教師評語:</b></p><p><b>  成績:</b></p><p>  填表時間:</p><p><b>  指導教師簽名: </b></p><p><b>  目錄&

9、lt;/b></p><p>  程序設計(大作業(yè))報告1</p><p>  昆明學院課程設計(大作業(yè))任務書2</p><p><b>  1.問題描述5</b></p><p><b>  2.基本要求5</b></p><p><b>  3.

10、數(shù)據(jù)結(jié)構(gòu)5</b></p><p><b>  4.總體設計5</b></p><p><b>  5.詳細設計6</b></p><p>  5.1程序流程圖6</p><p>  5.2初始化哈夫曼樹7</p><p>  5.3輸入權(quán)值函數(shù)7&l

11、t;/p><p>  5.4選擇根結(jié)點,存放權(quán)值最小和次小序號7</p><p>  5.5構(gòu)造哈夫曼樹7</p><p>  5.6根據(jù)哈夫曼樹求哈夫曼編碼7</p><p><b>  6.測試與調(diào)試7</b></p><p>  6.1程序步驟演示7</p><p&

12、gt;  6.1.1輸入各字符的權(quán)值7</p><p>  6.1.2輸入字符8</p><p>  6.1.3得到哈夫曼編碼8</p><p>  6.2程序測試結(jié)果8</p><p>  7.源程序清單10</p><p><b>  8.實驗心得13</b></p>

13、<p><b>  1.問題描述</b></p><p>  構(gòu)造一棵哈夫曼樹,根據(jù)所需輸入的字符數(shù)目,分別輸入字符的頻度和字符,得到它們相應的編碼,也就是設計一個哈夫曼編碼器。</p><p><b>  2.基本要求</b></p><p>  以字符的頻度為權(quán)值,建立哈夫曼樹,求哈夫曼編碼。根據(jù)字符及權(quán)值

14、得到其相應的編碼。</p><p><b>  3.數(shù)據(jù)結(jié)構(gòu)</b></p><p>  typedef struct </p><p>  {int weight; /*結(jié)點的權(quán)值*/</p><p>  int lchild,rchild,parent;

15、 /*左、右孩子及雙親的下標*/</p><p><b>  }htnode;</b></p><p>  typedef htnode huffmantree[m+1]; /* huffmantree是結(jié)構(gòu)數(shù)組類型,其0號單元不用,存儲哈夫曼樹 */</p><p>  typedef struct</p><p>

16、;  {char ch; /*存儲字符*/</p><p>  char code[n+1]; /*存放編碼位串*/</p><p>  }codenode;</p><p>  typedef codenode huffmancode[n+1]; /*huffmancode是結(jié)構(gòu)數(shù)組

17、類型,其0號單元不用,存儲哈夫曼編碼*/</p><p><b>  4.總體設計</b></p><p><b>  功能模塊劃分</b></p><p>  void main() //主函數(shù)</p><p>  void inithuffmantree

18、(huffmantree ht) //初始化哈夫曼樹函數(shù)inithuffmantree()</p><p>  void inputweight(huffmantree ht) //輸入權(quán)值函數(shù) </p><p>  void selectmin(huffmantree ht, int i, int *p1, int *p2)</p><p>  vo

19、id createhuffmantree(huffmantree ht) //構(gòu)造huffman樹,ht[m]為其根結(jié)</p><p>  void huffmancodes(huffmantree ht,huffmancode hcd) /*根據(jù)huffman樹ht求huffman編</p><p><b>  5.詳細設計</b></p><

20、;p><b>  5.1程序流程圖</b></p><p><b>  N</b></p><p><b>  Y</b></p><p>  5.2初始化哈夫曼樹</p><p>  void inithuffmantree(huffmantree ht)</p&

21、gt;<p><b>  5.3輸入權(quán)值函數(shù)</b></p><p>  void inputweight(huffmantree ht)</p><p>  5.4選擇根結(jié)點,存放權(quán)值最小和次小序號</p><p>  void selectmin(huffmantree ht, int i, int *p1, int

22、*p2)</p><p><b>  5.5構(gòu)造哈夫曼樹</b></p><p>  void createhuffmantree(huffmantree ht)</p><p>  5.6根據(jù)哈夫曼樹求哈夫曼編碼</p><p>  void huffmancodes(huffmantree ht,huffmanco

23、de hcd)</p><p><b>  6.測試與調(diào)試</b></p><p><b>  6.1程序步驟演示</b></p><p>  6.1.1輸入各字符的權(quán)值</p><p><b>  6.1.2輸入字符</b></p><p>  6.

24、1.3得到哈夫曼編碼</p><p><b>  6.2程序測試結(jié)果</b></p><p>  字符:R S T U V W X Y Z</p><p>  頻度:48 51 80 23 8 18 1 16 10</p><p>  字符: A B C D E F G H I J K L M N O P Q</

25、p><p>  頻度:186 64 13 22 32 103 21 15 47 57 1 2 32 20 57 63 15 1</p><p><b>  7.源程序清單</b></p><p>  #include<stdio.h></p><p>  #include<stdlib.h>

26、 // 用到系統(tǒng)標準輸出函數(shù)的</p><p>  #include<string.h></p><p>  #include<conio.h> //用到像getch()這種鍵盤輸入函數(shù)</p><p>  /* Huffman 樹的存儲結(jié)構(gòu)*/</p><p>  #defi

27、ne n 9 /*葉子數(shù)目根據(jù)需要設定*/</p><p>  #define m 2*n-1 /* Huffman 樹中結(jié)點總數(shù) */</p><p>  /* Huffman 樹的存儲結(jié)構(gòu)*/</p><p>  typedef struct /*結(jié)構(gòu)體定義*/</p><p>  

28、{int weight; /*結(jié)點的權(quán)值*/</p><p>  int lchild,rchild,parent; /*左、右孩子及雙親的下標*/</p><p>  }htnode; /*哈夫曼樹結(jié)點類型*/</p><p>  typedef htnode huffmantree[m+1]; /

29、* huffmantree是結(jié)構(gòu)數(shù)組類型,其0號單元不用,存儲哈夫曼樹 */</p><p>  typedef struct</p><p>  {char ch; /*存儲字符*/</p><p>  char code[n+1]; /*存放編碼位串*/</p><p>  }codenode

30、; /*編碼結(jié)點類型*/</p><p>  typedef codenode huffmancode[n+1]; /*huffmancode是結(jié)構(gòu)數(shù)組類型,其0號單元不用,存儲哈夫曼編碼*/</p><p>  void inithuffmantree(huffmantree ht) /*初始化哈夫曼樹函數(shù)inithuffmantree

31、()*/</p><p><b>  {int i;</b></p><p>  for(i=0;i<=m;i++)</p><p>  {ht[i].weight=0;</p><p>  ht[i].lchild=ht[i].rchild=ht[i].parent=0;</p><p>

32、<b>  }</b></p><p><b>  }</b></p><p>  void inputweight(huffmantree ht) /*輸入權(quán)值函數(shù) */</p><p><b>  {int i;</b></p><p>  for(i=1

33、;i<=n;i++)</p><p><b>  {</b></p><p>  printf(" ……請輸入第[%d]個權(quán)值: ",i);</p><p>  scanf("%d",&ht[i].weight);</p><p><b>  }</

34、b></p><p>  printf("\n");</p><p><b>  }</b></p><p>  void selectmin(huffmantree ht, int i, int *p1, int *p2)</p><p>  /* 在ht[1..i]中選兩個權(quán)值最小的

35、根結(jié)點,其序號為*p1和*p2,*p1中放權(quán)值最小的根結(jié)點的序號,*p2中放權(quán)值次小的根結(jié)點的序號*/</p><p>  {int j,min1,min2; /* min1,min2分別是最小權(quán)值和次小權(quán)值*/</p><p>  min1=min2=32767;</p><p>  *p1=*p2=0;</p&

36、gt;<p>  for(j=1;j<=i;j++)</p><p>  {if(ht[j].parent==0) /* j 為根結(jié)點*/</p><p>  if(ht[j].weight<min1||min1==32767)</p><p><b>  {</b></p>&l

37、t;p>  if(min1!=32767) {min2=min1; *p2=*p1;}</p><p>  min1=ht[j].weight; *p1=j;</p><p><b>  }</b></p><p><b>  else</b></p><p>  if(ht[j].

38、weight<min2||min2==32767)</p><p>  {min2=ht[j].weight; *p2=j;}</p><p><b>  }</b></p><p><b>  }</b></p><p>  void createhuffmantree(huffmantr

39、ee ht) /*構(gòu)造huffman樹,ht[m]為其根結(jié)點*/</p><p>  { </p><p>  int i,p1,p2;</p><p>  inithuffmantree(ht); /* 將ht初始化*/</p><p>  inputweight(ht)

40、; /* 輸入葉子權(quán)值至ht [1..n]的weight域*/</p><p>  for(i=n+1;i<=m;i++) /* 共進行n-1次合并,新結(jié)點依次存于ht[i]中*/</p><p>  {selectmin(ht,i-1,&p1,&p2); /*在ht [1.. i-1]中選

41、擇兩個權(quán)值最小的根結(jié)點,其序號分別為p1和p2*/</p><p>  ht[p1].parent=ht[p2].parent=i;</p><p>  ht[i].lchild=p1; /* 最小權(quán)值的根結(jié)點是新結(jié)點的左孩子*/</p><p>  ht[i].rchild=p2; /* 次小權(quán)值的根結(jié)點是新

42、結(jié)點的右孩子*/</p><p>  ht[i].weight=ht[p1].weight+ht[p2].weight;</p><p><b>  }</b></p><p><b>  }</b></p><p>  void huffmancodes(huffmantree ht,huffma

43、ncode hcd) /*根據(jù)huffman樹ht求huffman編碼*/</p><p><b>  {</b></p><p>  int c,p,i; /* c和p分別指示 ht中孩子和雙親的位置 */</p><p>  char cd[n+1];

44、 /* 臨時存放編碼*/</p><p>  int start; /* 指示編碼在cd 中的起始位置*/</p><p>  cd[n]='\0'; </p><p>  getchar(); /* 編碼結(jié)束符*/

45、</p><p>  printf("2.……請依次輸入字符……:");</p><p>  for(i=1;i<=n;i++) /* 依次求葉子ht [i]的編碼*/</p><p>  { hcd[i].ch=getchar(); /* 讀入葉子ht [i]對應的字符*/</p&

46、gt;<p>  start=n; /* 編碼起始位置的初值*/</p><p>  c=i; /* 從葉子ht [i]開始上溯*/</p><p>  while((p=ht[c].parent)!=0) /* 直至上溯到ht [ c]是樹根為止*/</p>&

47、lt;p>  { cd[--start]=(ht[p].lchild==c)?'0':'1'; /*若ht [ c]是ht[p]的左孩子,則生成代碼0,否則生成代碼1*/</p><p>  c=p; /* 繼續(xù)上溯*/</p><p><b>  }<

48、/b></p><p>  strcpy(hcd[i].code,&cd[start]); /* 復制編碼位串*/</p><p><b>  }</b></p><p>  printf("\n");</p><p>  printf("3.………哈夫曼編碼結(jié)果

49、為:……\n");</p><p>  printf("\n");</p><p>  for(i=1;i<=n;i++)</p><p>  printf(" ……第[%d]個字符[%c]的編碼為:%s\n",i,hcd[i].ch,hcd[i].code);</p><p><

50、;b>  }</b></p><p>  void main()</p><p>  {huffmantree t;</p><p>  huffmancode h;</p><p>  printf("|^^^^^^^^^^^^^^^^^^^^^^^^^^^*########################*^^

51、^^^^^^^^^^^^^^^^^|\n");</p><p>  printf("|^^^^^^^^^^^^^^^^^^^^^^^^^^^*歡迎使用哈弗曼編碼系統(tǒng)!*^^^^^^^^^^^^^^^^^^^|\n");</p><p>  printf("|^^^^^^^^^^^^^^^^^^^^^^^^^^^*###################

52、#####*^^^^^^^^^^^^^^^^^^^|\n");</p><p>  printf("\n");</p><p>  printf("1.…………請輸入%d個權(quán)值:……\n",n);</p><p>  printf("\n");</p><p>  crea

53、tehuffmantree(t); /* 構(gòu)造huffman樹*/</p><p>  huffmancodes(t,h); /* 構(gòu)造huffman編碼*/</p><p><b>  }</b></p><p><b>  8.實驗心得&

54、lt;/b></p><p>  通過這次課程設計,使我獲益匪淺。學好數(shù)據(jù)結(jié)構(gòu)對于我們是非常重要的,能使我們在以后的程序設計方面給我們很大的幫助。以此同時,這門課程的學習也是非常艱辛的,因為它比較抽象難懂,這需要我們在實踐中不斷的克服。</p><p>  將近一個多星期的設計工作,讓我體會到作為一個編程人員是非常辛苦的。一個程序從算法到實現(xiàn),再到應用開發(fā)是需要走很長的一段路,不是一

溫馨提示

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

評論

0/150

提交評論