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

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>
            亚洲一区二区毛片| 一本久久青青| 99re6这里只有精品| **性色生活片久久毛片| 一区二区在线观看视频| 国产一区二区三区精品欧美日韩一区二区三区 | 国产自产在线视频一区| 国产精品一二三四区| 国模私拍一区二区三区| 亚洲国产aⅴ天堂久久| 亚洲人成在线播放| 99视频在线精品国自产拍免费观看| 一本色道久久99精品综合| 亚洲欧美电影院| 久久精品在线观看| 亚洲国产精品va在线看黑人动漫| 欧美国产日本高清在线| 在线中文字幕不卡| 久久精品夜夜夜夜久久| 欧美日韩国产高清| 在线精品观看| 欧美主播一区二区三区| 亚洲欧洲日产国产综合网| 欧美专区亚洲专区| 国产日韩欧美在线看| 一区二区三区久久久| 久久永久免费| 久久精品123| 国产一区二区三区黄视频| 亚洲欧美日韩直播| 亚洲四色影视在线观看| 在线观看欧美激情| 亚洲一区免费在线观看| 欧美韩日一区二区| 欧美成人免费观看| 91久久国产综合久久| 美女精品国产| 欧美怡红院视频| 在线国产亚洲欧美| 麻豆久久婷婷| 免费视频最近日韩| 亚洲看片网站| 亚洲午夜精品久久| 国内精品免费午夜毛片| 亚洲国内自拍| 国产精品午夜在线| 久久精品中文字幕免费mv| 久久精品日产第一区二区| 亚洲国产精品久久久久秋霞影院| 美女主播视频一区| 欧美网站在线| 久久久综合香蕉尹人综合网| 欧美va亚洲va香蕉在线| 亚洲午夜一区| 欧美大片一区二区三区| 久久精品30| 国产精品久久久久久久免费软件| 欧美一区国产二区| 欧美日韩亚洲高清一区二区| 欧美影视一区| 国产精品午夜av在线| 亚洲免费激情| 亚洲精品国久久99热| 久久国产精品99国产精| 亚洲综合社区| 欧美三级韩国三级日本三斤| 欧美.日韩.国产.一区.二区| 欧美中文字幕在线观看| 亚洲人午夜精品免费| 亚洲视频第一页| 校园春色国产精品| 日韩午夜在线视频| 久久亚洲国产精品日日av夜夜| 在线电影一区| 亚洲影院污污.| 99国产精品视频免费观看一公开 | 久久五月天婷婷| 亚洲人成小说网站色在线| 久久精品一区二区三区不卡牛牛 | 欧美高清视频| 亚洲精品无人区| 午夜国产精品视频免费体验区| 欧美二区在线| 亚洲免费高清视频| 一区二区三区精品视频| 久久久久久91香蕉国产| 国产精品日韩高清| 久久精品国产精品亚洲精品| 久久成人综合视频| 国产一区视频在线观看免费| 久久综合电影| 亚洲欧美日本国产有色| 久久亚洲精品一区| 中日韩男男gay无套| 国产日本欧美一区二区| 久久久免费av| 亚洲乱码久久| 亚洲国产日韩美| 99国产精品久久久| 久久男人资源视频| 欧美国产日韩一区二区| 亚洲视频在线看| 亚洲日本va午夜在线影院| 先锋亚洲精品| 亚洲乱码国产乱码精品精天堂 | 欧美四级在线| 久久久综合激的五月天| 男女精品视频| 麻豆九一精品爱看视频在线观看免费| 亚洲美女区一区| 亚洲精品久久7777| 亚洲人成欧美中文字幕| 亚洲电影免费在线观看| 在线高清一区| 在线观看视频欧美| 黄色欧美成人| 亚洲福利久久| 亚洲国产精品成人va在线观看| 国产午夜精品美女毛片视频| 亚洲高清成人| 国产精品二区在线| 亚洲欧美综合精品久久成人| 亚洲第一精品久久忘忧草社区| 久热成人在线视频| 久久先锋资源| 欧美日韩在线视频观看| 欧美日韩国产综合网| 国产精品久久久久久久免费软件| 国产精品久久久久久久久久尿| 久久精品国产综合精品| 欧美1区2区视频| 亚洲精品国产精品久久清纯直播 | 欧美激情综合| 欧美影院成年免费版| 亚洲电影观看| 欧美一区二区福利在线| 久久这里只有| 欧美高清不卡在线| 先锋影音一区二区三区| 欧美激情综合五月色丁香小说| 国产精品天美传媒入口| 日韩午夜免费| 亚洲精品乱码久久久久久| 久久精品亚洲乱码伦伦中文 | 亚洲第一精品夜夜躁人人躁| 亚洲人妖在线| 欧美成人有码| 欧美本精品男人aⅴ天堂| 娇妻被交换粗又大又硬视频欧美| 一区二区三区精品视频在线观看| 玖玖玖免费嫩草在线影院一区| 亚洲欧美视频在线| 国产日韩在线一区| 久久精品在线| 欧美粗暴jizz性欧美20| 欧美日韩三级| 国产精品扒开腿做爽爽爽视频| 国产精品你懂得| 狠狠入ady亚洲精品经典电影| 亚洲二区在线视频| 美日韩精品视频| 嫩草成人www欧美| 亚洲免费观看| 亚洲伊人观看| 亚洲第一福利在线观看| 亚洲精品欧美日韩| 国产伦精品一区二区三区高清版 | 性久久久久久久久久久久| 99精品国产在热久久| 国产精品日日摸夜夜添夜夜av| 欧美亚洲综合久久| 亚洲免费在线精品一区| 欧美一区二区三区四区在线观看| 国产日产欧美a一级在线| 女主播福利一区| 国产精品自在在线| 亚洲国产成人精品久久| 国产亚洲aⅴaaaaaa毛片| 亚洲毛片视频| 亚洲三级免费| 免播放器亚洲一区| 久久久www成人免费精品| 国产精品一区二区久久久久| 91久久综合亚洲鲁鲁五月天| 一区二区三区在线观看视频| 亚洲欧美国产视频| 羞羞色国产精品| 国产精品久久久久久久久动漫| 亚洲精品日韩久久| 亚洲视频在线观看免费| 欧美日韩国产二区| 一区二区三区精品视频| 亚洲欧美精品一区| 国产日韩欧美综合在线| 久久国产黑丝| 亚洲精品男同| 欧美在线国产精品| 国产日韩欧美在线| 久久久国际精品| 日韩午夜中文字幕|