哈夫曼樹課程設(shè)計(jì)_第1頁
已閱讀1頁,還剩10頁未讀, 繼續(xù)免費(fèi)閱讀

下載本文檔

版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(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><b>  ---哈夫曼樹編碼</b></p><p><b>  哈夫曼樹編碼</b></p><p><b>  一、實(shí)現(xiàn)功能</b></p><p>  給出一串字符,根據(jù)每個(gè)字

2、符出現(xiàn)的頻數(shù)進(jìn)行編碼,將文字轉(zhuǎn)化為二進(jìn)制的字符組成的字符串,即加密。加密過程根據(jù)頻數(shù)生成哈夫曼樹,然后進(jìn)行遍歷,得到二進(jìn)制編碼。</p><p>  二、 哈夫曼算法敘述</p><p>  (1).根據(jù)給定的n個(gè)權(quán)值{w1,w2,…,wn}構(gòu)成n棵二叉樹的集合F={T1,T2,…,Tn},其中每棵二叉樹Ti中只有一個(gè)帶權(quán)值為Wi的根結(jié)點(diǎn),其左右子樹均為空。</p><

3、p> ?。?).在F中選取兩棵根結(jié)點(diǎn)的權(quán)值最小的樹作為左右子樹構(gòu)造一棵新的二叉樹,且置新的二叉樹的根結(jié)點(diǎn)的權(quán)值為其左右子樹上根結(jié)點(diǎn)的權(quán)值之和 </p><p> ?。?).在F中刪除這兩棵樹,同時(shí)將新得到的二叉樹加入F中。</p><p> ?。?).重復(fù)(2)和(3),直到F中只含一棵二叉樹為止,即哈夫曼樹。</p><p>  三、根據(jù)書上算法介紹進(jìn)行代碼

4、編寫(VC++編寫)</p><p>  1、哈夫曼樹的建立、初始化和遍歷</p><p>  void CHFMDlg::CrtHuffmanCoding(HuffmanTree &HT, HuffmanCode &HC, int *w,int n)</p><p><b>  {</b></p><p&g

5、t;  int m,i,s1,s2;</p><p><b>  m=2*n-1; </b></p><p>  HT=(HuffmanTree)malloc((m+1)*sizeof(HTNode)); </p><p>  for(i=1; i<=n; ++i) //1--n號(hào)存放葉子結(jié)點(diǎn),初始化 </p><p&

6、gt;<b>  {</b></p><p>  HT[i].weight=*w;</p><p>  HT[i].LChild=0; </p><p>  HT[i].parent=0; </p><p>  HT[i].RChild=0; </p><p><b>  } </

7、b></p><p>  for(i=n+1; i<=m; i++)</p><p><b>  {</b></p><p>  HT[i].weight=0; </p><p>  HT[i].LChild=0;</p><p>  HT[i].parent=0; </p>

8、;<p>  HT[i].RChild=0; </p><p><b>  }</b></p><p>  //非葉子結(jié)點(diǎn)初始化</p><p>  for(i=n+1; i<=m; i++) //創(chuàng)建非葉子結(jié)點(diǎn),建哈夫曼樹</p><p><b>  { </b></p&

9、gt;<p>  Select(HT,i-1,&s1,&s2);</p><p>  HT[s1].parent=i; </p><p>  HT[s2].parent=i; </p><p>  HT[i].LChild=s1;</p><p>  HT[i].RChild=s2;</p><

10、;p>  HT[i].weight=HT[s1].weight+HT[s2].weight; </p><p><b>  }</b></p><p>  char *cd; </p><p>  int j,start,p; </p><p>  unsigned int c; </p><p

11、>  HC=(HuffmanCode)malloc((n+1)*sizeof(char *)); //分配n個(gè)編碼的頭指針</p><p>  cd=(char *)malloc(n*sizeof(char)); //分配求當(dāng)前編碼的工作空間 </p><p>  cd[n-1]='\0'; </p><p>  //從右向左逐位存放編碼

12、,首先存放編碼結(jié)束符 </p><p>  for(j=1; j<=n; j++) //求n個(gè)葉子結(jié)點(diǎn)對(duì)應(yīng)的哈夫曼編碼 </p><p><b>  { </b></p><p>  start=n-1; //初始化編碼起始指針 </p><p>  for(c=j,p=HT[j].parent; p!=0

13、;c=p,p=HT[p].parent) </p><p>  //從葉子到根結(jié)點(diǎn)遍歷求編碼 </p><p>  if( HT[p].LChild==c) </p><p>  cd[--start]='0'; //左分支標(biāo)0</p><p><b>  else </b></p>&

14、lt;p>  cd[--start]='1'; //右分支標(biāo)1 </p><p>  HC[j]=(char *)malloc((n-start)*sizeof(char)); </p><p>  //為第i個(gè)編碼分配空間 </p><p>  strcpy(HC[j],&cd[start]);</p><p&

15、gt;<b>  }</b></p><p>  free(cd); </p><p><b>  }</b></p><p><b>  2、</b></p><p>  void CHFMDlg::Select(HuffmanTree HT, int n, int *s1,

16、 int *s2)</p><p>  //在HT[1]~HT[i-1]的范圍內(nèi)選擇兩個(gè)parent為0 </p><p>  //且weight最小的結(jié)點(diǎn),其序號(hào)分別賦值給s1、s2</p><p><b>  {</b></p><p>  int i,min; </p><p>  for(

17、i=1; i<=n; i++) </p><p><b>  { </b></p><p>  if(HT[i].parent==0) </p><p>  { min=i; break; } </p><p><b>  }</b></p><p>  for(i=1

18、; i<=n; i++)</p><p><b>  {</b></p><p>  if(HT[i].parent==0) </p><p><b>  { </b></p><p>  if(HT[i].weight<HT[min].weight) </p><p

19、><b>  min=i; </b></p><p><b>  } </b></p><p><b>  }</b></p><p><b>  *s1=min; </b></p><p>  for(i=1; i<=n; i++) <

20、/p><p><b>  { </b></p><p>  if(HT[i].parent==0 && i!=(*s1))</p><p>  { min=i; break; }</p><p><b>  } </b></p><p>  for(i=1; i&

21、lt;=n; i++)</p><p><b>  {</b></p><p>  if(ht[i].parent==0 && i!=(*s1))</p><p><b>  {</b></p><p>  if(HT[i].weight<HT[min].weight) <

22、;/p><p><b>  min=i;</b></p><p><b>  }</b></p><p><b>  } </b></p><p><b>  *s2=min; </b></p><p><b>  }<

23、/b></p><p>  四、 在MFC中進(jìn)行代碼編譯</p><p>  添加列表框顯示每個(gè)字符的編碼</p><p>  界面如下:CHFMDlg對(duì)話框</p><p>  void CHFMDlg::SetCtrlStyle(HWND hWnd, DWORD dwNewStyle)</p><p>  /

24、/設(shè)置列表控件風(fēng)格</p><p><b>  {</b></p><p>  DWORD dwOldStyle;</p><p>  dwOldStyle=GetWindowLong(hWnd,GWL_STYLE);</p><p>  if ((dwOldStyle&LVS_TYPEMASK)!=dwNew

25、Style)</p><p><b>  {</b></p><p>  dwOldStyle&=~LVS_TYPEMASK;</p><p>  dwNewStyle|=dwOldStyle;</p><p>  SetWindowLong(hWnd,GWL_STYLE,dwNewStyle);</p&g

26、t;<p><b>  }</b></p><p><b>  }</b></p><p>  BOOL CHFMDlg::OnInitDialog()//初始化列表控件</p><p><b>  {</b></p><p>  CDialog::OnInitD

27、ialog();</p><p><b>  ……………</b></p><p>  SetCtrlStyle(m_ListCtrl.m_hWnd,LVS_REPORT);</p><p>  CString strHeader[2]={"字符","編碼"};</p><p>  

28、int nWidth[2]={80,100};</p><p>  for (int nCol=0;nCol<2;nCol++)</p><p><b>  {</b></p><p>  m_ListCtrl.InsertColumn(nCol,strHeader[nCol],LVCFMT_LEFT,nWidth[nCol]);<

29、/p><p><b>  }</b></p><p>  return TRUE; </p><p><b>  }</b></p><p>  void CHFMDlg::OnOK()//編譯按鈕 </p><p><b>  {</b></p&g

30、t;<p>  // TODO: Add extra validation here</p><p>  UpdateData();</p><p>  CString strContent,str,strValue;</p><p>  strContent=m_strContent;//獲取編輯框中的字符串并賦//strContent</p&

31、gt;<p>  int size=strContent.GetLength();//獲得字符串長度</p><p>  str=strContent.GetAt(0);</p><p>  for (int i=0;i<size;i++)//將不同的字符存入str中</p><p><b>  {</b></p>

32、;<p><b>  int m=0;</b></p><p>  for (int j=0;j<str.GetLength();j++)</p><p>  if (strContent.GetAt(i)==str.GetAt(j))</p><p><b>  m++;</b></p>

33、<p>  if (m==0) str=str+strContent.GetAt(i);</p><p><b>  }</b></p><p>  int n=str.GetLength();</p><p>  int *strnum=new int(n);</p><p>  for (int k=0

34、;k<n;k++)//計(jì)算str中字符出現(xiàn)的次數(shù),即權(quán)值,存//入strnum數(shù)組中</p><p><b>  {</b></p><p>  int num=0;</p><p>  for (int j=0;j<size;j++)</p><p>  if (strContent.GetAt(j)==s

35、tr.GetAt(k))</p><p><b>  num++;</b></p><p>  strnum[k]=num;</p><p><b>  }</b></p><p>  HuffmanTree HT;</p><p>  HuffmanCode HC;<

36、/p><p>  CrtHuffmanCoding(HT,HC,strnum,n);</p><p>  CString strShow="";</p><p>  for (int m=0;m<size;m++)</p><p><b>  {</b></p><p> 

37、 for (int t=0;t<n;t++)</p><p>  if(strContent.GetAt(m)==str.GetAt(t))</p><p>  strShow=strShow+"*"+HC[t+1];</p><p><b>  }</b></p><p>  SetDlgIt

38、emText(IDC_EDIT2,strShow);</p><p>  for (int x=0;x<n;x++)</p><p><b>  {</b></p><p>  CString s=str.GetAt(x);</p><p>  Int nIndex=m_ListCtrl.InsertItem(m

39、_ListCtrl.GetItemCount(),s);</p><p>  m_ListCtrl.SetItemText(nIndex,1,HC[nIndex+1]);</p><p><b>  }</b></p><p><b>  }</b></p><p>  void CHFMDlg::

40、SetCtrlStyle(HWND hWnd, DWORD dwNewStyle)</p><p><b>  {</b></p><p>  DWORD dwOldStyle;</p><p>  dwOldStyle=GetWindowLong(hWnd,GWL_STYLE);</p><p>  if ((dwO

41、ldStyle&LVS_TYPEMASK)!=dwNewStyle)</p><p><b>  {</b></p><p>  dwOldStyle&=~LVS_TYPEMASK;</p><p>  dwNewStyle|=dwOldStyle;</p><p>  SetWindowLong(hWn

溫馨提示

  • 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. 眾賞文庫僅提供信息存儲(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)論