青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

ACM___________________________

______________白白の屋
posts - 182, comments - 102, trackbacks - 0, articles - 0
<2010年8月>
25262728293031
1234567
891011121314
15161718192021
22232425262728
2930311234

常用鏈接

留言簿(24)

隨筆分類(332)

隨筆檔案(182)

FRIENDS

搜索

積分與排名

最新隨筆

最新評論

閱讀排行榜

評論排行榜

霍夫曼編碼

Posted on 2010-08-27 19:20 MiYu 閱讀(876) 評論(0)  編輯 收藏 引用 所屬分類: ACM_資料ACM ( 數據結構 )

MiYu原創, 轉帖請注明 : 轉載自 ______________白白の屋    

 

代碼
霍夫曼編碼是一種被廣泛應用而且非常有效的數據壓縮技術,根據待壓縮數據的特征,一個可壓縮掉20%~90%。這里考慮的數據指的是字符串序列。要理解霍夫曼編碼,先要理解霍夫曼樹,即最優二叉樹,是一類帶權路徑長度最短的樹。

路徑是指從樹中一個結點到另一個結點之間的通路,路徑上的分支數目稱為路徑長度。

樹的路徑長度是從樹根到每一個葉子之間的路徑長度之和。結點的帶權路徑長度為從該結點到樹根之間的路徑長度與該結點權的乘積,樹的帶權路徑長度為樹中所有葉子結點的帶權路徑長度之和.

霍夫曼樹是指所有葉子結點的二叉樹中帶權路徑長度最小的二叉樹.

當給定了n個葉子結點的權值后,構造出的最優二叉樹的結點數目m就確定了,即m
=2n-1,所以可用一維結構數組來存儲最優二叉樹
#define MAXLEAFNUM 50           /*最優二叉樹中最大葉子樹目*/

struct node{

        
char ch;          /*當前結點表示的字符,對于非葉子結點,此域不用*/

        
int weight;              /*當前結點的權值*/

        
int parent;               /*當前結點的父結點的下標,為0時表示無父結點*/

        
int lchild,rchild;       /*當前結點的左,右孩子結點的下標,為0時表示無孩子結點*/

}HuffmanTree[
2 * MAXLEAFNUM];


typedef 
char *HuffmanCode[MAXLEAFNUM + 1];


/*創建最優二叉樹*/


void createHTree(HuffmanTree HT, char *c, int *w, int n)

{

        
/*數組c[0..n-1]和w[0..n-1]存放了n個字符及其概率,構造霍夫樹HT*/

        
int i, s1, s2;

        
if (n <= 1)

               
return;

        
/*根據n個權值構造n棵只有根結點的二叉樹*/

        
for (i=1; i<=n; i++)

        {

               HT[i].ch 
= c[i-1];

               HT[i].weight 
= w[i-1];

               HT[i].parent 
= HT[i].lchild = HT[i].rchild = 0;     

        }


        
for (; i<2*n; ++i)

        {

               HT[i].parent 
= 0;

               HT[i].lchild 
= 0;

               HT[i].rchild 
= 0;

        }


/*構造霍夫曼樹*/

        
for (i=n+1; i<2*n; i++)

        {

               
/*從HT[1..i-1]中選擇parent為0且weight最小的兩棵樹,其序號為s1和s2*/

               select(HT,i
-1,s1,s2);

               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;

        }

}
復制代碼
霍夫曼算法(構造靍夫曼樹)
  對應于霍夫曼樹的算法也叫做霍夫曼算法。此算法的思想是:
  (
1)設給定的一組權值為{W1,W2,W3,……Wn},據此生成森林F={T1,T2,T3,……Tn},F 中的每棵二叉樹只有一個帶權為W1的根節點(i=1,2,……n)。
 ?。?/span>2)在F中選取兩棵根節點的權值最小和次小的二叉樹作為左右構造一棵新的二叉樹,新二叉樹根節點的權值為其左、右子樹根節點的權值之和。
 ?。?/span>3)在F中刪除這兩棵最小和次小的二叉樹,同時將新生成的二叉樹并入森林中。
 ?。?/span>4)重復(2)(3)過程直到F中只有一棵二叉樹為止。
霍夫曼樹的應用非常廣,在不同的應用中葉子節點的權值可以作不同的解釋?;舴蚵鼧鋺糜谛畔⒕幋a中,權值可以看成某個符號出現的頻率;應用到判定過程中,權值可以看成某類數據出現的頻率;應用到排序過程中,權值可以看成是已排好次序而等待合并的序列長度等。


應用霍夫曼編碼


        假設有一個包含100 000個字符的數據文件要壓縮存儲。各字符在該文件中的出現頻度見表1。僅有6種不同字符出現過,字符a出現了45000次。

                    a       b      c      d       e       f

頻度(千字)   
45     13     12     16      9       5

固定代碼字      
000   001   010    011   100    101

變長代碼字      
0      101   100   111    1101   1100

表1   一個字符編碼問題。大小為100 000個字符的一個數據文件僅包含字符a
~f,每個字符出現的頻度如表中所示。如果對每個字符賦予一個三位的編碼,則該文件可被編碼為300000位。如果利用表中的可變長度編碼,該文件可被編碼為224000位。

可以用很多種方式來表示這樣一個文件。采用固定長度編碼,則需要三位二進制數字來表示六個字符:a
=000,b=001,…,f=101。這種方法需要300 000來對整個原文件編碼。

 

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            亚洲在线电影| 国产精品播放| 亚洲高清自拍| 午夜精品久久久久久| 在线视频精品一区| 一本久道综合久久精品| 在线视频亚洲欧美| 野花国产精品入口| 午夜精品久久久久影视| 欧美一区二区在线视频| 久久天堂国产精品| 亚洲成人资源网| 亚洲精品视频二区| 亚洲欧美另类综合偷拍| 久久夜色精品国产| 欧美精品亚洲二区| 国产精品有限公司| 永久久久久久| 在线一区视频| 久久国产黑丝| 亚洲国产精品成人综合色在线婷婷| 亚洲欧洲另类国产综合| 亚洲一区免费看| 久久伊伊香蕉| 国产精品色婷婷| 亚洲人成小说网站色在线| 亚洲男人的天堂在线| 美女脱光内衣内裤视频久久影院| 亚洲高清三级视频| 亚洲视频一区在线| 久久综合亚洲社区| 国产精品激情电影| 国模精品一区二区三区色天香| 亚洲人成人一区二区在线观看| 亚洲欧美怡红院| 亚洲国产mv| 性色一区二区| 欧美午夜剧场| 日韩视频二区| 久久中文字幕一区二区三区| 日韩视频不卡中文| 久久五月天婷婷| 国产女主播一区二区| 亚洲视频在线观看视频| 欧美高清在线精品一区| 先锋亚洲精品| 国产精品嫩草99av在线| 一本色道久久综合亚洲精品不| 欧美高清不卡在线| 久久久久国产精品一区三寸| 国产亚洲成av人在线观看导航| 亚洲在线第一页| 日韩特黄影片| 欧美三级网址| 一区二区精品在线| 欧美激情免费在线| 久久视频免费观看| 好男人免费精品视频| 久久激情久久| 亚洲在线观看| 亚洲国产欧美日韩精品| 久久国产精品久久久久久久久久 | 欧美日韩国产一级片| 亚洲成人自拍视频| 老司机免费视频久久| 久久疯狂做爰流白浆xx| 国产精品日韩在线观看| 亚洲欧美日韩直播| 亚洲一区三区电影在线观看| 国产精品一区二区在线| 欧美中文字幕视频在线观看| 欧美一区二区性| 亚洲国产国产亚洲一二三| 欧美国产日本| 欧美啪啪一区| 欧美影视一区| 老司机一区二区三区| 日韩视频第一页| 亚洲欧美电影院| 国产主播在线一区| 亚洲国产精品毛片| 国产精品扒开腿爽爽爽视频| 久久精品免费| 欧美国产一区二区在线观看| 亚洲伊人伊色伊影伊综合网 | 欧美激情综合亚洲一二区| 日韩视频一区二区在线观看| 一本色道久久综合亚洲精品高清| 国产精品久久久久影院色老大| 久久国产色av| 欧美精品国产| 欧美综合国产| 欧美福利一区| 欧美在线观看天堂一区二区三区| 久久一区二区三区四区五区| 中国女人久久久| 久久久免费精品视频| a4yy欧美一区二区三区| 先锋影院在线亚洲| 亚洲久久成人| 欧美伊人精品成人久久综合97| 亚洲精品欧美日韩| 欧美亚洲视频| 正在播放欧美视频| 久久av免费一区| 亚洲午夜精品久久| 久久一区激情| 欧美亚洲一区| 欧美日韩一二三区| 噜噜噜噜噜久久久久久91 | 国产毛片久久| 91久久精品日日躁夜夜躁国产| 国产精品色午夜在线观看| 亚洲国产高清视频| 国产资源精品在线观看| 在线亚洲伦理| 日韩午夜在线电影| 久久亚洲精品欧美| 亚洲电影免费观看高清完整版在线观看 | 亚洲国产日韩欧美一区二区三区| 国产免费成人| 一区二区三区久久网| 亚洲第一网站| 久久国产欧美| 久久国产一区二区三区| 国产精品久久7| 一区二区三区高清视频在线观看| 99精品国产一区二区青青牛奶| 裸体一区二区| 欧美激情小视频| 亚洲丁香婷深爱综合| 欧美专区18| 久久久人成影片一区二区三区| 国产精品网站视频| 亚洲欧美日韩成人| 欧美亚洲综合网| 国产日韩精品视频一区| 亚洲在线观看视频网站| 亚洲欧美在线看| 国产精品一区二区久激情瑜伽| 亚洲欧美另类国产| 久久精品在线| 国语精品中文字幕| 久久精品夜夜夜夜久久| 久久亚洲图片| 亚洲人成小说网站色在线| 欧美理论片在线观看| 99精品久久久| 午夜一区不卡| 国产一区二区三区网站 | 一区二区国产日产| 亚洲综合999| 国产精品伊人日日| 欧美一区二区三区在线看| 噜噜噜噜噜久久久久久91| 亚洲精品欧美在线| 欧美日韩精品| 亚洲欧美影音先锋| 美女尤物久久精品| 一区二区不卡在线视频 午夜欧美不卡在| 欧美特黄视频| 久久久久高清| 亚洲免费高清| 久久综合九色九九| 日韩视频精品| 国内精品视频666| 欧美日韩福利在线观看| 篠田优中文在线播放第一区| 欧美成人情趣视频| 亚洲视频在线观看免费| 国内精品久久久| 欧美激情精品久久久久久蜜臀 | 欧美日韩蜜桃| 欧美一级在线视频| 亚洲激情专区| 久久福利毛片| 日韩视频在线观看免费| 国产午夜精品久久| 欧美激情一区在线观看| 久久国内精品视频| 亚洲免费一在线| 欧美成人在线影院| 亚洲欧美日韩中文视频| 亚洲国产免费| 久久免费精品视频| 亚洲小视频在线观看| 亚洲高清不卡在线| 国产欧美大片| 欧美日韩国产一级| 你懂的亚洲视频| 欧美综合二区| 亚洲欧美一区二区三区在线| 99精品视频免费全部在线| 欧美第一黄网免费网站| 久久av一区二区三区漫画| 日韩亚洲成人av在线| 亚洲大片av| 国产主播一区| 国产欧美日本在线| 国产精品一区二区三区久久|