精品欧美一区二区三区在线观看 _久久久久国色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技術棧公眾號

国产成人高清视频| 久久久久亚洲| 欧美性生活影院| 99久久久无码国产精品性色戒| 97成人在线观看| 99视频一区| 日韩中文字幕精品| av免费观看不卡| 日韩成人亚洲| 亚洲小说欧美激情另类| 日本在线观看一区二区| 亚洲国产欧美另类| 日韩av不卡一区二区| 欧美高清在线观看| 亚洲天堂精品一区| 日韩精选在线| 日韩欧美国产精品一区| 亚州精品一二三区| 国产99在线| 亚洲色图在线视频| 日韩亚洲不卡在线| 天堂在线中文网| 国产在线精品一区二区三区不卡 | 伊人网在线视频观看| 免费观看性欧美大片无片| 欧洲视频一区二区| 亚洲午夜无码av毛片久久| 操你啦视频在线| 国产精品美女久久久久久久网站| 精品国产一区二区三区四区精华| 国产视频手机在线观看| 日韩av一区二区三区四区| 91成人免费观看网站| 国产第一页在线播放| 午夜国产精品视频| 久久韩剧网电视剧| 一本一本久久a久久| av一区二区高清| 国产丝袜一区二区三区免费视频| 四虎国产精品免费| 久久天堂久久| 日韩一区二区精品在线观看| 中文字幕成人免费视频| 青青热久免费精品视频在线18| 午夜激情一区二区三区| 无码 制服 丝袜 国产 另类| 女人黄色免费在线观看| 亚洲精品成人天堂一二三| 吴梦梦av在线| 麻豆tv入口在线看| 亚洲女子a中天字幕| 亚洲美女自拍偷拍| a视频在线免费看| 亚洲人成精品久久久久| 加勒比海盗1在线观看免费国语版| 日韩大片在线永久免费观看网站| 国产精品毛片a∨一区二区三区| 视频在线99| 97视频在线观看网站| 国产精品视频一二三区| 一区在线电影| 97影院秋霞午夜在线观看| 一区二区在线观看视频在线观看| 欧美交换配乱吟粗大25p| 欧美日韩经典丝袜| 精品福利樱桃av导航| 亚洲乱码中文字幕久久孕妇黑人| 都市激情亚洲一区| 精品视频1区2区3区| 在线播放免费视频| 成人影院中文字幕| 亚洲欧美日韩直播| 三级黄色在线观看| 国内视频精品| 日本不卡免费高清视频| 在线观看黄色国产| 国产91色综合久久免费分享| 久久精品国产一区二区三区日韩| 久久伊伊香蕉| 最新国产の精品合集bt伙计| 国产成人一区二区三区别| 毛片电影在线| 欧美日韩亚洲综合一区| 国产成人精品一区二区三区在线观看| 好吊妞国产欧美日韩免费观看网站| 日韩成人中文字幕| 91免费在线看片| 黄色亚洲精品| 国产精品扒开腿做爽爽爽的视频| 国产av无码专区亚洲a∨毛片| 99久久综合精品| 亚洲二区三区四区| 草莓视频丝瓜在线观看丝瓜18| 色哟哟一区二区| 杨幂一区二区国产精品| 欧美亚视频在线中文字幕免费| 尤物tv国产一区| 国产在线观看成人| 美女www一区二区| 国产精品9999久久久久仙踪林| 可以在线观看的av网站| 亚洲在线视频免费观看| 日韩精品无码一区二区三区免费| 国产专区精品| 亚洲视频在线播放| 国产午夜精品无码| 韩国毛片一区二区三区| 欧洲亚洲一区二区| 91超碰国产在线| 7777精品伊人久久久大香线蕉经典版下载| 日本性生活一级片| 99精品网站| 青青草99啪国产免费| h片在线免费看| 中文一区二区完整视频在线观看| 久久成人福利视频| 日韩一区免费| 久久精品最新地址| 中文字幕欧美人妻精品| 久久综合久色欧美综合狠狠| 国内自拍中文字幕| www久久久| 在线视频一区二区| www.欧美色| 99久久精品国产一区二区三区| 日本成人性视频| 黄色成人小视频| 亚洲午夜精品久久久久久久久久久久| 日韩精品一卡二卡| 成人晚上爱看视频| 999久久欧美人妻一区二区| 国内欧美日韩| 日韩在线播放av| 精品久久久久久久久久久久久久久久 | 欧美国产日韩视频| 99精品久久久久久中文字幕| **欧美大码日韩| xxxx在线免费观看| 欧美gayvideo| 国产一区在线播放| 午夜精品一区| 欧美精品 国产精品| 日韩av片在线免费观看| 精品一区二区在线免费观看| 一区二区av| 日韩成人在线一区| 久久综合亚洲社区| 国产黄色片免费| 亚洲曰韩产成在线| yjizz视频| 亚洲另类黄色| 久久偷窥视频| 日韩三区在线| 中文字幕日本欧美| 一级片视频网站| 日韩美女视频一区| 俄罗斯女人裸体性做爰| 欧美涩涩网站| 久久综合伊人77777麻豆| 一区二区三区短视频| 亚洲一区二区久久| 136福利视频导航| 亚洲精品乱码久久久久久黑人| 亚洲女人在线观看| 影音先锋中文字幕一区| 久久综合九色99| 日韩毛片在线| 久久久精品国产亚洲| 国内精品久久久久久久久久久| 亚洲国产中文字幕在线视频综合| 一级欧美一级日韩片| 日韩专区一卡二卡| 正在播放久久| 露出调教综合另类| 国产精品视频在线播放| 99热国产在线| 亚洲人成网站999久久久综合| 中文字幕乱码视频| 一区二区在线看| 国产又粗又猛又爽视频| 久久国产精品露脸对白| 97干在线视频| 成人羞羞在线观看网站| 99视频国产精品免费观看| 女厕盗摄一区二区三区| 久久精品成人一区二区三区| 少妇高潮久久久| 欧美午夜精品一区二区三区| 久久久久久久久久久久国产| 久久久久久久精| 一个人看的视频www| 久久久久久网| 日韩一级片一区二区| 精品一区三区| 99re资源| 成人四虎影院| 91精品国产九九九久久久亚洲| 最新av网站在线观看| 亚洲精品电影久久久| ,亚洲人成毛片在线播放| 黑人巨大精品欧美一区二区一视频 | 日韩手机在线观看视频| 国产精品mm| 色一情一乱一伦一区二区三欧美| 91成人入口| 国产免费一区二区三区在线能观看| 成年人黄色大片在线| 久久伊人精品一区二区三区| 国产剧情在线观看| 亚洲国产精品人久久电影| 国产精品久久久久久久久毛片 | 中文字幕欧美视频| 日本麻豆一区二区三区视频| 国产主播自拍av| 欧美一区二区| 亚洲欧美日韩另类精品一区二区三区| 欧美成人一区在线观看| 51成人做爰www免费看网站| 久久久久黄色| 国产精品aaa| 麻豆蜜桃在线观看| 97色在线观看| 牛牛精品在线| 欧美精品在线网站| 日本高清视频在线观看| 中国日韩欧美久久久久久久久| 污视频网站免费观看| 精品奇米国产一区二区三区| h片在线免费看| 91精品国产综合久久精品app| 免费在线不卡av| 色哟哟精品一区| 国产精品久久久久久久久久精爆| 亚洲在线视频一区| 国产一级一片免费播放放a| 亚洲一区二区三区免费视频| 婷婷在线精品视频| 亚洲激情第一区| 久草视频中文在线| 亚洲午夜久久久久久久久久久| 欧美日韩综合一区二区| 亚洲精品欧美在线| 欧美高清视频一区二区三区| 一区二区三区四区精品在线视频 | 国产高清美女一级毛片久久| 亚洲人高潮女人毛茸茸| 每日更新在线观看av| 亚洲欧洲在线看| 成人好色电影| 久久久www成人免费精品| 快射视频在线观看| 美日韩精品视频免费看| 青春草免费在线视频| 欧美日韩国产成人高清视频| 超级碰碰不卡在线视频| 欧美中文字幕在线视频| 99蜜月精品久久91| 91精品视频专区| av毛片精品| 久久国产精品亚洲va麻豆| 免费成人网www| 亚洲 日韩 国产第一区| 在线电影一区二区| 免费观看国产精品视频| 亚洲主播在线| 日本人视频jizz页码69| 国产麻豆午夜三级精品| 人妻av一区二区| 久久久久久久av麻豆果冻| 国产主播av在线| 亚洲一区二区美女| 黄色片网站在线免费观看| 欧美日韩精品欧美日韩精品| 国产男女猛烈无遮挡| 亚洲精品成a人在线观看| 国产三级视频在线| 久精品免费视频| 午夜日韩成人影院| 91精品综合久久| 国产精品密蕾丝视频下载| av磁力番号网| 久久精品二区三区| 中文字幕精品一区二区三区在线| 国产成人精品免费网站| 亚洲色成人网站www永久四虎| 国产精品国产馆在线真实露脸| 国产一卡二卡在线播放| 欧美日韩精品一二三区| 日本美女一级片| www.久久色.com| 密臀av在线| 国产精品美女在线观看| 精品三级在线观看视频| 黄瓜视频免费观看在线观看www| 日韩午夜免费视频| 日本77777| 国产午夜亚洲精品理论片色戒 | 国产精品国产三级国产专区53| 神马久久一区二区三区| 欧美乱做爰xxxⅹ久久久| 免费看欧美美女黄的网站| 日韩精品视频一区二区| 综合久久久久久| 日韩精品久久久久久免费| 日韩精品一区二区三区在线| 91露出在线| 热久久这里只有| 超碰成人在线观看| 强开小嫩苞一区二区三区网站| 久久久成人网| 中文字幕天堂网| 亚洲精品ww久久久久久p站| 丰满人妻一区二区三区四区| 日韩成人中文电影| a级片在线免费| 成人黄色在线免费观看| 97精品一区二区| 91香蕉视频污版| 91女厕偷拍女厕偷拍高清| 久久久久亚洲av成人片| 91精品一区二区三区久久久久久 | 亚洲欧美日韩国产手机在线| 一区二区三区麻豆| 亚洲欧美制服丝袜| 忘忧草在线影院两性视频| 国产欧美在线一区二区| 欧美激情精品久久久六区热门| 天天干天天玩天天操| 国产精品婷婷午夜在线观看| 免费黄色片视频| 亚洲一区www| 国产精品第一国产精品| 蜜桃导航-精品导航| 亚洲欧美高清| 中国极品少妇videossexhd| 亚洲aaa精品| 天天av天天翘| 69av在线视频| 亚洲婷婷丁香| 成年人免费大片| 国产欧美精品区一区二区三区| 波多野结衣在线观看一区| 国产亚洲成精品久久| 韩日精品一区| 亚洲视频在线观看日本a| 久久99国产精品免费| 国产精品99久久久久久成人| 这里只有精品电影| 色呦呦在线视频| 精品乱色一区二区中文字幕| 亚洲欧美日韩视频二区| 91久久免费视频| 欧美视频一区二区三区| 蜜桃视频网站在线观看| 亚洲曰本av电影| 亚洲精品精选| 日本一级免费视频| 欧美老女人在线| 免费在线看污片| 久久久亚洲综合网站| 日日欢夜夜爽一区| 欧美视频www| 亚洲第一福利在线观看| 欧洲亚洲两性| 自拍偷拍99| 97aⅴ精品视频一二三区| www.五月婷婷.com| 久久99视频精品| 欧美网色网址| 天天干天天玩天天操| 亚洲va在线va天堂| 精品欧美不卡一区二区在线观看| 国产精品香蕉国产| 国产中文一区| 91精彩刺激对白露脸偷拍| 8x福利精品第一导航| 91豆花视频在线播放| 偷拍视频一区二区| 成人aa视频在线观看| 无码免费一区二区三区| 欧美成人一区二区三区电影| 色愁久久久久久| 午夜视频在线网站| 欧美午夜影院在线视频| 精品自拍一区| 日本福利一区二区三区| 国产一区二区三区免费观看| 亚洲久久在线观看| 久久综合九色九九| 啄木系列成人av电影| 亚洲AV无码久久精品国产一区| 一本大道久久a久久精品综合| 快射av在线播放一区| 欧美日韩最好看的视频| 国产精品99久久久| 男人天堂视频在线| 97精品视频在线观看| 天天av综合| av电影网站在线观看| 亚洲国产另类久久精品|