精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

用哈弗曼編碼實現壓縮軟件

開發 開發工具
哈夫曼編碼(Huffman Coding)是一種編碼方式,哈夫曼編碼是可變字長編碼(VLC)的一種。uffman于1952年提出一種編碼方法,該方法完全依據字符出現概率來構造異字頭的平均長 度最短的碼字,有時稱之為最佳編碼,一般就叫作Huffman編碼。本文介紹了用哈弗曼編碼實現壓縮軟件,一起來看。

哈夫曼壓縮是個無損的壓縮算法,一般用來壓縮文本和程序文件。哈夫曼壓縮屬于可變代碼長度算法一族。意思是個體符號(例如,文本文件中的字符)用一個特定長度的位序列替代。因此,在文件中出現頻率高的符號,使用短的位序列,而那些很少出現的符號,則用較長的位序列。我們先來看基本概念。 

1.什么是哈夫曼樹?

哈夫曼樹是一種***二叉樹,它的***點體現在它的的帶權路徑長度最小。(結點的帶權路徑長度為:結點的路徑長度乘以結點的權值,樹的帶權路徑長度為所有葉子結點帶權路徑長度之和)

2.什么是哈弗曼編碼?

從哈弗曼樹的根結點開始,按照左子樹分配代碼“0”,右子樹分配代碼“1”的規則,直到葉子結點為止,每個葉子結點的哈弗曼編碼就是從根結點開始,一直到該葉子結點為止,把途中經過的代碼按順序串起來就OK了。

3.什么是哈弗曼壓縮?

Huffman( 哈夫曼 ) 算法在上世紀五十年代初提出來了,它是一種無損壓縮方法,在壓縮過程中不會丟失信息熵,而且可以證明 Huffman 算法在無損壓縮算法中是***的。 Huffman 原理簡單,實現起來也不困難,在現在的主流壓縮軟件得到了廣泛的應用。對應用程序、重要資料等絕對不允許信息丟失的壓縮場合, Huffman 算法是非常好的選擇。

哈夫曼壓縮,一般用來壓縮文本和程序文件。哈夫曼壓縮屬于可變代碼長度算法一族。意思是個體符號(例如,文本文件中的字符)用一個特定長度的位序列替代。因此,在文件中出現頻率高的符號,使用短的位序列,而那些很少出現的符號,則用較長的位序列。

有了以上的基本概念,我們就可以動手實現哈弗曼壓縮軟件了!

4.哈弗曼壓縮軟件的實現:

在文件中,所有的數據都是以字節的形式存在的,一個字節是8位,所以所有可能出現的字節在0——256之間(不包括256),所以,***步要做的事情就是,把文件所有的字節的出現頻率統計出來,并用頻率做為權值生成一棵哈弗曼樹:

Java代碼:

  1. int[] ByteCount = new int[256];//字節頻率統計  
  2. InputStream fis = new FileInputStream(pathName_former);  
  3. InputStream bis = new BufferedInputStream(fis);//創建文件輸入流  
  4. while(bis.available()>0){  
  5. int tmp = bis.read();  
  6. ByteCount[tmp]++;  
  7. }//統計頻率  
  8. //構造哈弗曼樹  
  9. hfmTree hfm = new hfmTree(ByteCount);  
  10. Java代碼  
  11. public hfmTree(int[] rank){//根據頻率構造哈弗曼樹  
  12. //把頻率不為零的字節加入節點優先級隊列  
  13. PriorityQueue nodes = new java.util.PriorityQueue();  
  14. for(int i=0;i  
  15. if(rank[i]!=0){  
  16. nodes.add(new hfmNode(rank[i],i));  
  17. }  
  18. }  
  19. //構造哈弗曼樹  
  20. while(nodes.size()!=1){  
  21. hfmNode node_1 = nodes.poll();//1  
  22. hfmNode node_2 = nodes.poll();//2  
  23. hfmNode addNode = new hfmNode(node_1.getRank()+node_2.getRank(),0);  
  24. addNode.setLeft(node_1);  
  25. addNode.setRight(node_2);  
  26. nodes.add(addNode);  
  27. }  
  28. root = nodes.poll();  
  29. }//構造函數(correct) 

 

接下來,要做的就是獲得0——256之間每個字節所對應的哈弗曼編碼,用一個String[] Code = new Code[256]保存下來:

  1. Java代碼//獲得編碼  
  2. private void getStrByte(hfmNode node,String s){  
  3. if(node.getLeft()==null&&node.getRight()==null){  
  4. Code[node.getData()] = s;//獲得編碼字符串  
  5. }  
  6. if(node.getLeft()!=null){  
  7. getStrByte(node.getLeft(),s+"0");  
  8. }//左零 if(node.getRight()!=null){  
  9. getStrByte(node.getRight(),s+"1");  
  10. }//右1  
  11. }  
  12. 然后就是把每個字節的編碼長度打入文件:Java代碼//先將0-255的編碼長度打到文件里  
  13. for(int i=0;i  
  14. if(Code[i]==null||Code[i]==""){  
  15. Code[i] = "";  
  16. bos.write(0);  
  17. }else{  
  18. bos.write(Code[i].length());  
  19. }  

接下來就是,將每個字節的編碼打入文件(這里需要吧8個長度的01串轉換成一個byte打入文件):

  1. Java代碼//把每個字節的編碼表打到文件里  
  2. int i = 0;//第i個字節  
  3. int count = 0;//滿8打一,計數器  
  4. String writeCode = "";//寫入的8位編碼  
  5. String allCode = "";//所有待寫入的編碼  
  6. String inCode = "";  
  7. while(i<256||count>=8){  
  8. if(count>=8){//滿8  
  9. writeCode = allCode.substring(0,8);//前8位  
  10. count-=8;  
  11. allCode = allCode.substring(8);  
  12. bos.write(changeString(writeCode));//寫入一個字節  
  13. }else{  
  14. count+=Code[i].length();  
  15. allCode+=Code[i];  
  16. inCode+=Code[i];  
  17. i++;//嚴重錯誤發生地  
  18. }  
  19. }  
  20. //如果不滿8位的  
  21. if(allCode.length()>0){  
  22. int len = 8-allCode.length();//補零  
  23. for(int j=0;j  
  24. allCode+="0";  
  25. }  
  26. inCode+=allCode;  
  27. bos.write(changeString(allCode));  

 

***就是把文件中的所有字節按照這種哈弗曼的編碼方式保存到文件中,過程類似于上一步(在***打入末尾補入的0的個數,主要是為了方便解壓縮):Java代碼//編碼表輸出完畢,將文件中的字節按照這種編碼方式壓縮。

  1. InputStream ins = new FileInputStream(pathName_former);  
  2. InputStream buf = new BufferedInputStream(ins);//創建輸入流  
  3. count = 0;  
  4. writeCode = "";  
  5. allCode = "";  
  6. while(buf.available()>0||count>=8){  
  7. if(count>=8){//滿8  
  8. writeCode = allCode.substring(0,8);//前8位  
  9. count-=8;  
  10. allCode = allCode.substring(8);  
  11. bos.write(changeString(writeCode));//寫入一個字節  
  12. }else{  
  13. int data = buf.read();  
  14. count+=Code[data].length();  
  15. allCode+=Code[data];  
  16. }  
  17. }  
  18. //如果不滿8位的  
  19. if(allCode.length()>0){  
  20. int len = 8-allCode.length();//補零  
  21. for(int j=0;j  
  22. allCode+="0";  
  23. }  
  24. bos.write(changeString(allCode));  
  25. bos.write(len);//補入了幾個0  
  26. }else{  
  27. bos.write(0);//補入了0個0  

到這里,整個壓縮過程基本完成了。希望對大家有幫助。

【編輯推薦】

  1. 詳細解析Java中抽象類和接口的區別
  2. 如何在Java應用程序中動態分配CPU資源
  3. 常見的十四種Java開發工具的特點
  4. JavaScript開發規范要求
  5. JavaBean中使用JDBC方式進行事務處理
責任編輯:于鐵 來源: 互聯網
相關推薦

2011-04-28 10:07:24

哈弗曼編碼

2021-06-16 17:36:39

節點編碼哈夫曼樹

2015-03-03 14:10:53

shellcode哈夫曼編碼Huffy

2010-03-23 09:54:35

好壓壓縮

2021-04-24 07:50:59

壓縮軟件電腦

2021-10-31 07:24:12

Windows 11操作系統微軟

2022-06-22 07:50:47

NanaZip7-Zip開源

2021-03-12 19:40:55

Linux開源壓縮軟件

2011-08-11 16:41:09

bzip2中文man

2018-05-06 23:08:12

2022-12-20 11:20:07

PeaZip 8開源壓縮軟件

2021-12-30 08:25:35

開源壓縮軟件7-Zip 21.07

2010-09-10 15:56:08

2021-01-04 21:00:53

開源軟件文件解壓開發者工具

2011-12-15 10:38:06

OPEN聯盟以太網

2017-02-28 10:33:31

Python原理圖解

2016-01-08 19:10:00

京東智能

2023-05-09 09:00:39

7-Zip開源壓縮軟件

2022-05-09 11:46:49

亞馬遜云科技汽車哈曼
點贊
收藏

51CTO技術棧公眾號

欧美电影三区| 免费在线观看黄色| 国产精品久久777777毛茸茸| 精品小视频在线| 亚洲综合色在线观看| 韩国三级在线观看久| 日韩国产精品大片| 久久国产精品久久久久久| 女性生殖扒开酷刑vk| 四虎成人在线| 亚洲国产一区二区在线播放| 日本一区二区免费看| а√中文在线资源库| 米奇777在线欧美播放| 久久黄色av网站| 免费看黄色aaaaaa 片| 自拍偷拍亚洲图片| 日韩欧美主播在线| 精品日韩在线播放| 免费黄网站在线观看| 国产91精品露脸国语对白| 国产精品久久久久久久久免费看| 久久精品国产亚洲AV无码麻豆| 精品国产美女| 亚洲国产精品成人va在线观看| 黄色手机在线视频| 成人一区福利| 亚洲不卡一区二区三区| 一区二区三区四区五区精品| 亚州视频一区二区三区| 国产一区二区成人久久免费影院| 日本一欧美一欧美一亚洲视频| 久久国产在线观看| 婷婷精品进入| 国产一区二区三区三区在线观看 | 在线h片观看| 国产午夜精品一区二区三区嫩草 | 尤物视频一区二区| 亚洲免费视频一区| 男操女在线观看| 99麻豆久久久国产精品免费优播| 91超碰在线电影| 一二区在线观看| 蜜桃久久久久久久| 国产精品jizz在线观看麻豆| 亚洲男人第一av| 在线看片欧美| 国产做受高潮69| 欧美日韩中文字幕在线观看| 久久精品青草| 日韩视频在线一区| 欧美一区二区三区粗大| 成人激情免费视频| 在线中文字幕日韩| 国产免费一区二区三区网站免费| 国产成人精品一区二区免费看京| 亚洲精品久久久一区二区三区 | 亚洲综合在线视频| 国产精品日韩三级| 黄色羞羞视频在线观看| 亚洲国产裸拍裸体视频在线观看乱了 | 欧美不卡一区| 欧美夫妻性生活视频| 久久久久久av无码免费网站| 国语精品一区| 亚洲91av视频| 91av在线看| 综合电影一区二区三区 | 日韩色在线观看| 中文字幕一区二区在线观看视频| 一区二区三区日| 国产精品久久久久久麻豆一区软件 | 簧片在线免费看| 日韩电影免费观| 在线中文字幕一区| 在线观看免费av网址| 国产免费av国片精品草莓男男| 88在线观看91蜜桃国自产| 日韩av自拍偷拍| 最新国产一区二区| 亚洲电影av在线| 疯狂揉花蒂控制高潮h| 国产一区99| 久久不射热爱视频精品| 久久精品久久国产| 日韩精品一级中文字幕精品视频免费观看 | 久青草国产97香蕉在线视频| 久久精品久久精品久久| 久久青草久久| 91色在线观看| 婷婷五月综合激情| 国产精品免费av| 国产欧美日韩网站| 成人1区2区| 日韩你懂的电影在线观看| 醉酒壮男gay强迫野外xx| 欧美电影免费播放| 97视频com| 亚洲成人av网址| 粉嫩欧美一区二区三区高清影视| 欧美日韩日本网| av理论在线观看| 一本到不卡精品视频在线观看| 夜夜夜夜夜夜操| 欧美福利在线播放网址导航| 日韩在线观看你懂的| 国产乡下妇女做爰视频| 蜜桃av一区二区三区电影| 国产福利久久精品| аⅴ资源新版在线天堂| 亚洲图片欧美色图| 91高清国产视频| 香蕉一区二区| 欧美成人精品在线播放| 日日骚av一区二区| 成人av午夜电影| 综合网五月天| 亚洲爱爱视频| 99国产麻豆精品| 欧洲一区在线电影| 欧美日韩理论片| 国产精品视频一区二区三区四蜜臂| 久久久www成人免费精品| 激情视频网站在线观看| 福利一区二区在线观看| 杨幂一区欧美专区| 少妇精品视频一区二区免费看| 日韩免费视频一区二区| 欧美日韩午夜视频| 蜜臀国产一区二区三区在线播放| 久久一区二区三区av| 日本动漫理论片在线观看网站 | 中文字幕在线观看不卡视频| 白嫩少妇丰满一区二区| 精品视频自拍| 国语自产精品视频在线看抢先版图片| 国产精品无码专区av免费播放| 国产调教视频一区| 久久久久久久久久久久久久国产| 超碰在线一区| 色综合视频一区中文字幕| 伊人久久一区二区| 久久婷婷久久一区二区三区| 男人添女人下部高潮视频在观看| 91成人福利| 久久91精品国产| 亚洲国产精品久久久久爰性色| 成人欧美一区二区三区在线播放| 一区二区三区韩国| 精品精品久久| 国产精品视频网| 神马久久久久| 日本乱人伦一区| 久久久久无码精品国产sm果冻| 欧美亚洲三级| 日韩一本精品| 日韩第二十一页| 久久久精品亚洲| 国产视频在线观看免费| 亚洲欧美成人一区二区三区| 日韩欧美中文视频| 国产一在线精品一区在线观看| 444亚洲人体| av有码在线观看| 精品视频久久久久久久| 欧美一区二区三区不卡视频| 国产香蕉久久精品综合网| 亚洲欧美激情网| 欧美电影一二区| 亚洲在线免费观看| 国产精品一品| 日韩精品在线观看网站| 国产真人无遮挡作爱免费视频| 欧美激情综合网| 日本高清一区二区视频| 欧美日韩p片| 久久精品美女| 激情久久一区二区| 欧美精品日韩三级| 日韩精品视频在线观看一区二区三区| 91国内精品野花午夜精品| 99久久精品久久亚洲精品| 国产福利一区二区三区在线视频| 久久久久日韩精品久久久男男| 欧美另类极品videosbestfree| 国产成人自拍视频在线观看| 国产精品区一区二区三含羞草| 欧美激情一区二区视频| 不卡一区二区在线| 成人精品小视频| 亚洲国产精品日韩专区av有中文| 国产精品一区二区免费看| 欧美二三四区| 久久99热精品| 中文在线a天堂| 精品国产一区二区三区香蕉沈先生| 2019中文在线观看| 在线播放日本| 亚洲国产欧美精品| 国产精品美女一区| 黑人巨大精品欧美一区免费视频| 国产极品美女在线| 久久久欧美精品sm网站| 99视频在线观看视频| 亚洲综合二区| 天天想你在线观看完整版电影免费| 夜夜春成人影院| 成人国产1314www色视频| 欧美日韩国产网站| …久久精品99久久香蕉国产| www红色一片_亚洲成a人片在线观看_| 日韩精品高清在线观看| 国产xxxx在线观看| 欧美日韩高清在线| 最新中文字幕在线观看视频| 亚洲大片精品永久免费| 日本在线一级片| 欧美国产视频在线| 中文幕无线码中文字蜜桃| 国产99久久久精品| 久久久久久久久久毛片| 免费在线视频一区| 无码人妻丰满熟妇区五十路百度| 在线免费观看欧美| 亚洲爆乳无码精品aaa片蜜桃| 日韩在线视屏| 日本高清一区| 中国av一区| 久久国产精品一区二区三区四区| 亚洲成人黄色| 久久色.com| www.黄色网址.com| 久久国产电影| 日韩精品一线二线三线| 日韩有码中文字幕在线| 黑人中文字幕一区二区三区| 一区二区三区视频播放| 99se婷婷在线视频观看| 激情不卡一区二区三区视频在线| 国产欧美日韩免费| 日本成人福利| 国产美女扒开尿口久久久| 日韩成人亚洲| 国产精品高潮粉嫩av| 久久久成人av毛片免费观看| 国产精品免费久久久| 成人黄色免费观看| 国产欧美婷婷中文| 欧美一区二区三区婷婷| 成人在线视频福利| 亚洲男人在线| 成人羞羞国产免费| 亚洲视频国产精品| 韩国一区二区三区美女美女秀 | 国产成人av一区二区三区| 秋霞一区二区| 国产一区二区视频在线免费观看| 欧美精品国产白浆久久久久| 久久精品99| 欧美一二区在线观看| 亚洲欧美日韩精品综合在线观看| 日韩欧美视频专区| 国产麻豆电影在线观看| 欧美人成在线| 131美女爱做视频| 三级影片在线观看欧美日韩一区二区 | 欧美一区二区三区粗大| 亚洲图片激情小说| 久久久久久久国产视频| 午夜av一区二区三区| aaaaaa毛片| 欧美日韩精品欧美日韩精品一| 国产情侣在线播放| 亚洲国内精品视频| 成全电影播放在线观看国语| 日韩在线播放一区| 国产精品国精产品一二| 欧美一级视频免费在线观看| av在线播放一区| 444亚洲人体| 天堂日韩电影| 亚洲图片都市激情| 亚洲狼人精品一区二区三区| 欧美日韩大尺度| 国产一区二区三区免费观看| 亚洲天堂资源在线| 中文天堂在线一区| 黄页网站免费观看| 在线视频一区二区免费| jizz中国女人| 亚洲欧美一区二区三区情侣bbw| 欧美性猛交xxx乱大交3蜜桃| 久久久久国色av免费观看性色 | 91久久国产综合久久91精品网站 | 欧美极度另类| 91视频99| 国产欧美日韩免费观看| 蜜桃视频一区二区在线观看| 视频一区二区中文字幕| 欧美成人乱码一二三四区免费| 不卡欧美aaaaa| 亚洲一二三四五六区| 粉嫩av一区二区三区免费野| 国产美女免费看| 国产亚洲美女久久| 色在线中文字幕| 亚洲最大福利视频网| 成人影院天天5g天天爽无毒影院| 一本大道综合伊人精品热热| 国产网站在线看| 欧美日韩三级在线| 亚洲人成色777777老人头| 欧美超级乱淫片喷水| 欧美xxxx做受欧美护士| 国产精品一区视频| 影视一区二区| 色呦色呦色精品| 国产欧美日本一区视频| 免费在线观看黄网站| 日韩精品一区二区三区四区| 麻豆传媒在线免费看| 国产精品久久久久国产a级| 日韩电影不卡一区| 日韩久久久久久久久久久久| 韩国欧美国产1区| 国产极品视频在线观看| 91国在线观看| 亚洲av成人无码久久精品老人 | 欧美大奶子在线| 成人在线啊v| 制服诱惑一区| 美女任你摸久久| 影音先锋制服丝袜| 色婷婷久久久综合中文字幕| 四虎精品在永久在线观看 | 日本中文字幕免费观看| 日韩一区二区三区免费看| 日本亚洲精品| 91精品久久久久久久久| 久久久综合色| 污色网站在线观看| 国产精品久久久久久久浪潮网站| 91porny九色| 中文字幕亚洲欧美一区二区三区 | 久久美女免费视频| 欧美性猛交xxxx乱大交| 美女毛片在线看| 国产成人精品日本亚洲| av在线不卡顿| 五月激情婷婷在线| 日韩美女久久久| 国产免费黄色网址| 九九热99久久久国产盗摄| 日韩一区二区三区高清在线观看| 天天干天天色天天爽| 国产精品99久久久久久宅男| 中文字幕在线观看成人| 欧美精品一区二区三区蜜桃| 福利在线免费视频| 久久伊人一区| 免费观看一级特黄欧美大片| 女性裸体视频网站| 日韩欧美精品在线视频| 黑人极品ⅴideos精品欧美棵| 极品尤物一区二区三区| 午夜在线视频观看日韩17c| 日本黄色小视频在线观看| 欧美日韩国产大片| 蜜臀av在线| 久久伦理网站| 老司机午夜精品99久久| 农村黄色一级片| 亚洲激情视频在线播放| 无人区在线高清完整免费版 一区二| 五月天久久狠狠| 国产黄人亚洲片| av片免费观看| 久久精品中文字幕电影| 97久久综合精品久久久综合| heyzo亚洲| 国产精品久久毛片av大全日韩| 99久久一区二区| 日本精品久久久| 影音先锋日韩在线| 强伦人妻一区二区三区| 欧美精品一二三四| а√天堂中文资源在线bt| 日韩欧美视频第二区| 国产精品亚洲一区二区三区妖精| 久久久国产高清| 久久精品福利视频| 亚洲另类av| 激情久久综合网| 日韩欧美中文字幕在线观看 | 69**夜色精品国产69乱| 日韩电影免费网址| 亚洲 欧美 日韩在线| 欧美日韩精品欧美日韩精品| 理论不卡电影大全神| 中国 免费 av|