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

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

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

1.什么是哈夫曼樹?

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

2.什么是哈弗曼編碼?

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

 

 

3.什么是哈弗曼壓縮?

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

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

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

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

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

Java代碼

  1. int[] ByteCount = new int[256];//字節頻率統計     
  2.              
  3.         InputStream fis = new FileInputStream(pathName_former);          
  4.         InputStream bis = new BufferedInputStream(fis);//創建文件輸入流     
  5.              
  6.         while(bis.available()>0){     
  7.             int tmp = bis.read();     
  8.             ByteCount[tmp]++;     
  9.         }//統計頻率     
  10.              
  11.         //構造哈弗曼樹     
  12.         hfmTree hfm = new hfmTree(ByteCount);   

 

Java代碼

  1. public hfmTree(int[] rank){//根據頻率構造哈弗曼樹     
  2.     
  3.         //把頻率不為零的字節加入節點優先級隊列     
  4.         PriorityQueue nodes = new java.util.PriorityQueue();     
  5.              
  6.         for(int i=0;i
  7.             if(rank[i]!=0){     
  8.                 nodes.add(new hfmNode(rank[i],i));     
  9.             }     
  10.         }     
  11.         //構造哈弗曼樹     
  12.         while(nodes.size()!=1){     
  13.             hfmNode node_1 = nodes.poll();//1     
  14.             hfmNode node_2 = nodes.poll();//2     
  15.             hfmNode addNode = new hfmNode(node_1.getRank()+node_2.getRank(),0);     
  16.             addNode.setLeft(node_1);     
  17.             addNode.setRight(node_2);     
  18.             nodes.add(addNode);     
  19.         }     
  20.              
  21.         root = nodes.poll();     
  22.              
  23.              
  24.     }//構造函數(correct)    

 

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

Java代碼

  1. //獲得編碼     
  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.         }//左零     
  9.         if(node.getRight()!=null){     
  10.             getStrByte(node.getRight(),s+"1");     
  11.         }//右1     
  12.     }    

 

然后就是把每個字節的編碼長度打入文件:

Java代碼

  1. //先將0-255的編碼長度打到文件里     
  2.         for(int i=0;i
  3.             if(Code[i]==null||Code[i]==""){     
  4.                 Code[i] = "";     
  5.                 bos.write(0);     
  6.             }else{     
  7.                 bos.write(Code[i].length());     
  8.             }     
  9.         }    

 

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

Java代碼

  1. //把每個字節的編碼表打到文件里     
  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));     
  28.         }    

 

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

Java代碼

  1. //編碼表輸出完畢,將文件中的字節按照這種編碼方式壓縮     
  2.         InputStream ins = new FileInputStream(pathName_former);     
  3.         InputStream buf = new BufferedInputStream(ins);//創建輸入流     
  4.         count = 0;     
  5.         writeCode = "";     
  6.         allCode = "";     
  7.              
  8.         while(buf.available()>0||count>=8){     
  9.             if(count>=8){//滿8     
  10.                 writeCode = allCode.substring(0,8);//前8位     
  11.                 count-=8;     
  12.                 allCode = allCode.substring(8);     
  13.                 bos.write(changeString(writeCode));//寫入一個字節     
  14.             }else{     
  15.                 int data = buf.read();     
  16.                 count+=Code[data].length();     
  17.                 allCode+=Code[data];     
  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.             bos.write(changeString(allCode));     
  27.             bos.write(len);//補入了幾個0     
  28.         }else{     
  29.             bos.write(0);//補入了0個0     
  30.         }    

 

到這里,整個壓縮過程基本完成了,解壓縮就是壓縮的逆過程,在此不再贅述,所有的操作都保存在附上源代碼中。

【編輯推薦】

  1. Java編碼問題完全解決方案
  2. 淺談Java中的編碼理論
  3. JAVA里字符編碼的探索與理解
責任編輯:金賀 來源: ITEYE博客
相關推薦

2011-05-20 14:03:31

哈夫曼

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開源壓縮軟件

2012-10-11 09:46:20

2021-12-30 08:25:35

開源壓縮軟件7-Zip 21.07

2010-09-10 15:56:08

2021-01-04 21:00:53

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

2012-12-12 10:22:54

SDN虛擬化

2011-12-15 10:38:06

OPEN聯盟以太網

2010-01-05 16:58:43

圖片處理

2017-02-28 10:33:31

Python原理圖解
點贊
收藏

51CTO技術棧公眾號

999国产精品| www在线观看黄色| 丝袜美腿高跟呻吟高潮一区| 中文字幕欧美专区| 亚洲成人手机在线观看| 久久国产精品黑丝| 久久综合九色综合欧美98| 国产精品久久视频| 高h视频免费观看| 欧美色资源站| 欧美日韩精品专区| 狠狠久久亚洲欧美| 色777狠狠综合秋免鲁丝| 人妻精品久久久久中文字幕69| segui88久久综合| 国产欧美日产一区| 风间由美一区二区三区| 国产免费一级视频| 欧美成人嫩草网站| 亚洲天堂av女优| 91丨porny丨九色| 超薄肉色丝袜脚交一区二区| 一区二区三区不卡视频| 日韩国产伦理| 手机av免费在线观看| 麻豆91在线观看| 7m精品福利视频导航| 911国产在线| 综合干狼人综合首页| 日韩午夜激情av| 99热这里只有精品在线播放| h片在线观看下载| 亚洲日本一区二区| 视频在线99| 天堂中文在线8| 国产成人精品免费看| 国产色视频一区| 丁香社区五月天| 一本色道久久综合一区| 欧美日产国产成人免费图片| 丁香六月激情综合| 午夜a一级毛片亚洲欧洲| 欧美成人vps| 国产探花在线观看视频| 成人全视频在线观看在线播放高清| 午夜精品视频在线观看| 8x8x华人在线| 黄色一级片在线观看| xf在线a精品一区二区视频网站| 99re资源| 亚洲欧美激情国产综合久久久| 麻豆国产欧美日韩综合精品二区| 日本国产欧美一区二区三区| 国产精品自拍视频一区| 欧美a级片网站| 久久这里只有精品99| 呻吟揉丰满对白91乃国产区| 欧美日韩在线二区| 一区二区成人av| 色噜噜噜噜噜噜| 精品一区二区三| 一区二区三区动漫| 久久久久久成人网| 久久精品高清| 久久人人爽亚洲精品天堂| 日韩av毛片在线观看| 日韩一区电影| 北条麻妃99精品青青久久| 免费成人美女女在线观看| 久久免费精品视频在这里| 色婷婷综合成人| 91麻豆免费视频网站| 欧美不卡在线| 97久久精品人人澡人人爽缅北| 国产午夜精品无码| 欧美一级网站| 国产精品91视频| 中文字幕+乱码+中文字幕明步| 六月丁香婷婷久久| 亚洲va男人天堂| 欧美视频一二区| 久久综合丝袜日本网| 视频一区二区在线| 97caopron在线视频| 亚洲线精品一区二区三区八戒| 国产av人人夜夜澡人人爽麻豆| xxxxxx欧美| 欧美日韩精品欧美日韩精品一综合| 美女网站色免费| 日韩成人在线观看视频| 日韩av影视综合网| 五月婷婷欧美激情| 欧美日韩福利| 国产成人精品在线视频| 国产又黄又大又粗的视频| 国产高清亚洲一区| 欧美日韩国产综合视频在线| 日本天堂在线观看| 国产精品久久久久免费a∨| 中文字幕免费高清在线观看| 国产精品自拍毛片| 久久国产精品 国产精品| 国产九九在线| 伊人婷婷欧美激情| 久久久久久久久久久久久国产精品 | 麻豆传媒一区| 国产婷婷视频在线| 福利一区视频在线观看| 欧美特黄aaa| 日日天天久久| 欧美精品日韩三级| 特级西西444www大胆免费看| 国产成人av一区二区三区在线 | 五月天亚洲婷婷| 亚洲欧美日韩一级| 麻豆国产欧美一区二区三区r| 最新国产精品拍自在线播放 | 韩国无码一区二区三区精品| 日韩久久视频| 国产91精品久| 午夜精品久久久久久久99| 亚洲国产精品t66y| 国产极品粉嫩福利姬萌白酱| 精品一区二区三区免费看| 亚洲视频专区在线| 在线天堂中文字幕| 国产乱码一区二区三区| 亚洲精品高清国产一线久久| 桃色av一区二区| 欧美精品久久99| 精品人妻中文无码av在线| 国产日本精品| 国产伦精品一区二区三毛| 黄色免费在线看| 欧美视频精品在线观看| 中文字幕在线免费看线人| 激情视频一区二区三区| 99国产在线| 黄网址在线观看| 欧美日韩一本到| 成人激情五月天| 久久亚洲视频| 日本一区二区在线视频| 亚洲人成午夜免电影费观看| 精品久久久久久久一区二区蜜臀| 五月天婷婷色综合| 国产另类ts人妖一区二区| 咪咪色在线视频| 91精品国产色综合久久不卡粉嫩| 中文字幕亚洲自拍| 中日韩av在线| 欧美国产精品v| 日本a√在线观看| 欧美中文一区二区| 国产精品久久久久久久久借妻| 黄色在线视频观看网站| 色综合色狠狠天天综合色| 六月婷婷七月丁香| 久久午夜激情| 午夜精品美女久久久久av福利| 无人区在线高清完整免费版 一区二| 亚洲欧美综合图区| 国产91av在线播放| 国产精品久久久久久久久果冻传媒 | 欧美日韩亚洲丝袜制服| 长河落日免费高清观看| 久久99久久99小草精品免视看| 尤物一区二区三区| 国产精品亚洲四区在线观看| 美日韩丰满少妇在线观看| 99国产成人精品| 亚洲一区二区三区激情| 国产麻豆剧传媒精品国产av| 国产一区二区三区成人欧美日韩在线观看 | 国产乱码在线观看| 国产精品国产三级国产| 中文字幕一区二区在线观看视频 | 日本精品久久久久中文字幕| 国产欧美日韩精品一区二区免费| 国产精品久久综合av爱欲tv| 91网在线看| 亚洲成人久久一区| av一级在线观看| 日韩理论片在线| 亚洲天堂2024| 免费在线视频一区| 精品国产一区二区三区无码| 亚洲女娇小黑人粗硬| 国产在线a不卡| caoprom在线| 伊人久久精品视频| 丰满少妇被猛烈进入| 色综合久久88色综合天天| 亚洲精品久久久久久国| 波波电影院一区二区三区| 五月婷婷狠狠操| 亚洲精选久久| 国产人妻互换一区二区| 欧美一级三级| 91在线视频一区| 一本大道色婷婷在线| 久久九九全国免费精品观看| 涩涩视频免费看| 欧美嫩在线观看| 日本特级黄色片| 亚洲人成精品久久久久| 好吊日免费视频| 国产成人精品影视| xxxx一级片| 亚洲精品综合| 久久亚洲a v| 日韩精品欧美| 久久国产精品高清| 日韩精品久久久久久久软件91| 青青草精品毛片| 精品一性一色一乱农村| 亚洲网在线观看| 免费国产羞羞网站视频| 欧美日韩一区二区欧美激情| 日本在线播放视频| 亚洲成人av福利| 国产美女久久久久久| 国产亚洲欧美色| 无码精品一区二区三区在线播放| 国内精品久久久久影院薰衣草 | 亚洲欧美日韩国产中文| 亚洲欧美高清视频| 欧美一区二区不卡视频| 一区二区三区免费在线| 一本大道久久a久久精二百| 国产精品6666| 夜夜嗨av一区二区三区四季av| 国产又粗又猛又爽又黄的视频四季| 99精品在线观看视频| 激情av中文字幕| 国产剧情一区在线| 91亚洲一区二区| 精品一区二区三区免费毛片爱| 成人精品视频一区二区| 麻豆精品网站| wwwxxx黄色片| 久久精品毛片| 亚洲成熟丰满熟妇高潮xxxxx| 日韩香蕉视频| 欧美国产激情视频| 亚洲一区欧美激情| 亚洲欧洲日产国码无码久久99| 1024日韩| 日日橹狠狠爱欧美超碰| 中文亚洲欧美| 欧美成人免费高清视频| 亚洲在线网站| 日韩一级片播放| 奇米精品一区二区三区四区| 色乱码一区二区三区在线| 麻豆国产精品一区二区三区| 91视频这里只有精品| 精品无人码麻豆乱码1区2区| 99视频在线观看视频| 国产很黄免费观看久久| 秘密基地免费观看完整版中文| 99久久久精品| 亚洲综合网在线观看| 国产午夜久久久久| 蜜桃av免费在线观看| 亚洲日本中文字幕区| 久久精品视频6| 欧美性xxxx| 丰满熟女人妻一区二区三| 欧美日韩一二三区| av一区二区三| 亚洲第一中文字幕| 日本在线视频1区| 在线观看欧美www| www久久日com| 91国内精品久久| 亚洲日本网址| 95av在线视频| 丝袜久久网站| 中文字幕欧美人与畜| 欧美日韩精品| 无码无遮挡又大又爽又黄的视频| 免费高清成人在线| 日韩成人av影院| 国产色婷婷亚洲99精品小说| 久艹在线观看视频| 亚洲五码中文字幕| 艳妇乳肉豪妇荡乳av无码福利| 91精品国产高清一区二区三区| 黄色一级a毛片| 国产亚洲日本欧美韩国| 中文字幕中文字幕在线中高清免费版 | 欧美午夜精品理论片a级按摩| 国产精品主播一区二区| 亚洲电影免费观看高清| av在线日韩国产精品| 色综合久久中文字幕综合网小说| 亚洲女色av| 9a蜜桃久久久久久免费| 国产a久久精品一区二区三区| 性欧美18一19内谢| 美女黄网久久| 熟妇女人妻丰满少妇中文字幕 | 182在线观看视频| 欧美日韩亚洲成人| 97免费观看视频| 亚洲欧美日本另类| 青草av在线| 国产日韩亚洲欧美| 亚洲瘦老头同性70tv| 青青草视频国产| 美女看a上一区| 成人精品在线观看视频| 亚洲六月丁香色婷婷综合久久 | 男人av资源站| 色美美综合视频| 五月天婷婷社区| 欧美日韩ab片| 国产一区精品二区| 亚洲精品欧美精品| 亚洲永久视频| 精品人妻伦一二三区久| 亚洲欧美日韩精品久久久久| 国产在线一级片| 亚洲免费av网址| 2018av在线| 成人性色av| 国产综合精品| 欧美日韩一区二区区| 国产精品久久久久久户外露出| 日韩中文字幕在线观看视频| 精品国产一区二区精华| 国产盗摄在线观看| 国产精品视频99| 欧美日韩国产高清电影| 黄色片视频在线免费观看| 成人视屏免费看| 国产精品成人网站| 亚洲成人av在线| av日韩中文| 久久精品国产精品青草色艺| 亚洲大片av| v天堂中文在线| 午夜精品在线视频一区| 日韩一级片免费| 国内精品在线一区| 99re热精品视频| 99亚洲国产精品| 国产老肥熟一区二区三区| 中文字幕在线有码| 日韩视频一区二区| 在线观看的网站你懂的| 97超碰人人看人人| 欧美午夜国产| 日本一区二区在线观看视频| 亚洲韩国精品一区| 日韩一级片免费在线观看| 69av成年福利视频| 亚洲毛片免费看| 特级丰满少妇一级| 中文字幕一区在线观看视频| 99久久精品国产一区色| 欧美日韩第一页| 美女福利一区| 欧洲熟妇精品视频| 亚洲欧洲日本在线| 成 人片 黄 色 大 片| 久久久久久久久久久亚洲| 羞羞色国产精品网站| 岳毛多又紧做起爽| 国产精品午夜在线| 国产按摩一区二区三区| 国模精品视频一区二区三区| 妖精视频一区二区三区| 天天影视综合色| 亚洲免费观看高清在线观看| 免费a级片在线观看| 日本国产欧美一区二区三区| 成人在线一区| 无码国产精品久久一区免费| 欧美日韩国产精品专区| 成人精品一区二区三区免费 | 欧美激情一区二区三区蜜桃视频 | 毛片不卡一区二区| 波多野结衣亚洲色图| 日韩久久免费电影| 玖玖精品在线| 日本福利视频在线| 国产精品福利电影一区二区三区四区| 午夜精品无码一区二区三区| 欧美一区二区色| 91精品啪在线观看国产81旧版| av av在线| 欧美日韩国产三级| brazzers在线观看| 在线观看日韩羞羞视频| 成人av网在线| 国产又粗又长又大视频| 4438全国成人免费| 亚洲电影在线一区二区三区|