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

亚洲欧洲久久久| 2018国产在线| www.黄色国产| 香蕉久久夜色精品| 日韩在线观看网站| 在线免费黄色小视频| 91吃瓜在线观看| 亚洲国产精华液网站w| 亚洲自拍高清视频网站| 可以免费在线观看的av| 天天射综合网视频| 亚洲美女久久久| 国产xxx在线观看| av免费在线一区| 亚洲成人午夜影院| 中国人体摄影一区二区三区| 手机在线观看免费av| 男女男精品视频| 97香蕉久久夜色精品国产| а天堂中文在线资源| 欧美三级午夜理伦三级小说| 欧美精品三级日韩久久| 欧美黄网站在线观看| caoporn免费在线| 国产午夜精品福利| 国产亚洲欧美一区二区三区| 国产老妇伦国产熟女老妇视频| 羞羞视频在线观看欧美| 久久久久久久香蕉网| 美女视频久久久| 九九热线有精品视频99| 亚洲精品在线网站| 少妇欧美激情一区二区三区| 欧美色999| 欧美午夜精品久久久久久久| 成人一级生活片| 黄色在线播放网站| 国产精品美女久久久久av爽李琼 | 精品国产亚洲日本| 欧洲视频一区二区| 久久久免费视频网站| 怡红院在线观看| 成人欧美一区二区三区| 日韩在线观看电影完整版高清免费| 亚洲欧美另类综合| 国产激情一区二区三区| 亚洲xxx视频| 99热这里只有精品99| 精久久久久久久久久久| 国产精品国产福利国产秒拍| 国产又粗又爽视频| 美女诱惑黄网站一区| 欧美在线观看日本一区| 成人精品免费在线观看| 国产精品人人爽人人做我的可爱| 高清一区二区三区四区五区| 国产一国产二国产三| 在线视频观看日韩| 97热在线精品视频在线观看| 在线观看 中文字幕| 欧美日本中文| 97视频在线观看免费| 日韩欧美一区二区一幕| 亚洲精选在线| 日本一本a高清免费不卡| 国产精品乱码一区二区视频| 日韩成人一级大片| 国产日韩欧美日韩大片| 91精品中文字幕| 国产精品综合二区| 狠狠色综合网站久久久久久久| 国产suv一区二区| 岛国一区二区在线观看| 精品人伦一区二区三区| 蜜芽tv福利在线视频| 国产欧美精品一区二区三区四区 | 综合久久亚洲| 九九精品视频在线观看| 国产黄色片视频| 蜜桃视频一区| 国产精品美女免费视频| 国产日产亚洲系列最新| 本田岬高潮一区二区三区| 乱色588欧美| 日本在线观看| 亚洲成av人片一区二区三区| 欧美日韩在线视频一区二区三区| 惠美惠精品网| 欧美一区二区视频在线观看2020| 尤物网站在线观看| 欧美理论视频| 欧美精品电影免费在线观看| 亚洲中文一区二区| 国产电影一区二区三区| 欧美乱偷一区二区三区在线| 日本三级在线播放完整版| 亚洲在线视频一区| 在线免费视频a| 99香蕉久久| 中文字幕av日韩| 国产一级片久久| 青青草一区二区三区| 国产aⅴ精品一区二区三区黄| 欧美视频综合| 一区二区三区在线免费播放| 日本精品一区二区三区四区| 粉嫩一区二区三区在线观看| 亚洲欧美一区二区三区久久| 欧美人妻精品一区二区三区 | 四虎在线免费看| 中文字幕亚洲在| 久久久999视频| 精品国产欧美| 最近2019中文字幕第三页视频| 久久精品久久国产| 国内精品不卡在线| 欧美日韩一区二区视频在线观看 | 日本xxxx免费| 色综合久久网| 国产99久久精品一区二区| 国产综合在线播放| 国产精品高潮呻吟久久| 精品一卡二卡三卡| 国产人妖ts一区二区| 久久精品夜夜夜夜夜久久| 国产情侣免费视频| 91女人视频在线观看| 国产av熟女一区二区三区| 日韩久久99| 在线观看国产成人av片| 久久亚洲天堂网| av网站一区二区三区| 久久久久久av无码免费网站下载| 久久女人天堂| 色av吧综合网| 中文字幕久久熟女蜜桃| 久久免费精品国产久精品久久久久| 日韩一区二区高清视频| 白嫩亚洲一区二区三区| 久久久91精品国产| 亚洲系列在线观看| 国产精品日日摸夜夜摸av| 最新中文字幕免费视频| 精品freesex老太交| 国产成人精品久久久| 黑人与亚洲人色ⅹvideos| 狠狠躁18三区二区一区| 免费看黄色aaaaaa 片| 亚洲在线黄色| 欧美日韩天天操| 国产综合色区在线观看| 亚洲欧美日韩国产精品| 久久亚洲精品石原莉奈 | 日韩精品欧美一区二区三区| www.com.cn成人| 亚洲人成网站在线播| 免费视频网站在线观看入口| 国产欧美一区视频| 亚洲免费黄色录像| 午夜精彩国产免费不卡不顿大片| 91深夜福利视频| 四虎av在线| 亚洲第一中文字幕| 6080午夜伦理| 国产精品久久777777| 国产美女视频免费看| 综合一区在线| 国产欧美一区二区三区不卡高清| 激情黄产视频在线免费观看| 亚洲欧洲偷拍精品| 在线免费看毛片| 亚洲美女少妇撒尿| 黄色污在线观看| 日韩精品一级二级| 午夜探花在线观看| 精品国产导航| 国产精品电影在线观看| 国产成人l区| 亚洲精品成人久久久| 人人草在线观看| 亚洲日本丝袜连裤袜办公室| youjizz.com日本| 久久综合网络一区二区| 波多野结衣三级在线| 国产精品17p| 国产美女久久精品| 成人女同在线观看| 国产亚洲日本欧美韩国| www香蕉视频| 日本道色综合久久| 18岁成人毛片| 国产亚洲欧美一级| 亚洲国产欧美日韩在线| 亚洲免费中文| 中国女人做爰视频| 美女毛片一区二区三区四区| 91久久精品国产91性色| 午夜激情电影在线播放| 少妇av一区二区三区| 五十路在线视频| 91精品综合久久久久久| 日韩中文字幕在线观看视频| **性色生活片久久毛片| 国产白嫩美女无套久久| 激情av综合网| 国产av人人夜夜澡人人爽| 亚洲图片在线| 国产大尺度在线观看| 免费视频亚洲| 精品国产乱码一区二区三区四区| 日韩国产一二三区| 奇米四色中文综合久久| 色图在线观看| 久久久精品久久| 粉嫩av在线播放| 亚洲精品网站在线播放gif| 亚洲av综合色区无码一区爱av| 欧美亚洲国产一区在线观看网站| 日产精品久久久久| 亚洲精品成人在线| 性欧美一区二区| 91女神在线视频| v天堂中文在线| 国产电影精品久久禁18| 国产精品自在自线| 老司机免费视频一区二区| 男人天堂网视频| 翔田千里一区二区| 成年人观看网站| 国产精品一区亚洲| 一区二区传媒有限公司| 欧美精品色网| 欧美黄色免费网址| 综合激情在线| 黑人巨茎大战欧美白妇| 亚洲一区二区三区无吗| 伊人av成人| 欧美激情国产在线| 亚洲欧洲精品一区二区| 成人女性视频| 亚洲国产精品综合| 爽成人777777婷婷| 亚洲欧美日韩精品久久久| 成人在线免费小视频| 特级西西444www大精品视频| 国产精品一区二区三区av麻| 欧美欧美一区二区| 精品国产乱码久久久| 亚洲精品国产系列| 91影院成人| 欧美一级特黄aaaaaa在线看片| 我不卡影院28| 国产人妻人伦精品| 狠狠入ady亚洲精品经典电影| 97中文字幕在线| 亚洲一区免费| 日日噜噜噜噜久久久精品毛片| 青青草视频一区| 在线视频日韩欧美| av成人老司机| 日韩精品电影一区二区| 国产精品日韩成人| 成人免费视频网站入口::| 亚洲曰韩产成在线| 美女又爽又黄免费视频| 色欧美片视频在线观看| 中文字幕 欧美激情| 91精品综合久久久久久| 黄色美女一级片| 亚洲三级 欧美三级| 2017亚洲天堂1024| 九九综合九九综合| 日本不卡1234视频| 国产裸体写真av一区二区| 蜜桃精品视频| 欧美lavv| 亚洲精品小说| 亚洲欧洲日产国码无码久久99| 日韩影院在线观看| 制服.丝袜.亚洲.中文.综合懂| 92精品国产成人观看免费| 五月婷婷六月香| 一区二区三区成人在线视频| 五月天婷婷久久| 欧美精三区欧美精三区| 日韩一区二区三区不卡| 这里只有精品丝袜| 大黄网站在线观看| 国产精品aaaa| 国产精东传媒成人av电影| 日韩尤物视频| 国产精品久久国产愉拍| 国产美女18xxxx免费视频| av电影天堂一区二区在线| 国产成人免费在线观看视频| 性久久久久久久久| 91高潮大合集爽到抽搐| 精品一区二区三区四区| а√天堂官网中文在线| 国产成人精品一区二区三区| 欧美一区在线观看视频| 亚洲激情一区二区三区| 亚洲免费高清| 少妇高潮一69aⅹ| 国产精品美女久久久久久久久久久 | 91精品国产91久久久久久| 免费视频观看成人| 另类小说综合网| 亚洲国产婷婷| 国内av免费观看| 中文字幕在线一区| 超碰在线观看91| 精品视频—区二区三区免费| 羞羞污视频在线观看| 国产精品尤物福利片在线观看| 人人香蕉久久| 久久久性生活视频| 高清不卡在线观看av| 国产大片免费看| 欧美日韩电影一区| 国产私拍精品| 欧洲成人午夜免费大片| 国产成人一二片| 日本大片免费看| 国产黄色91视频| 婷婷社区五月天| 欧美日韩在线播放三区四区| 欧美女v视频| 青青草97国产精品免费观看 | 国产·精品毛片| 国产男女猛烈无遮挡在线喷水| 在线亚洲免费视频| 日韩有码电影| 91av在线影院| 午夜精品影视国产一区在线麻豆| 国产免费一区二区视频| 国产精品99久久久久久有的能看| 四虎地址8848| 91.com在线观看| 麻豆传媒视频在线观看免费| 国产精品黄页免费高清在线观看| 国产亚洲精品美女久久久久久久久久| 每日在线更新av| 久久人人超碰精品| 亚洲另类在线观看| 亚洲视频欧美视频| 精品网站在线| 中文字幕一区二区三区精彩视频 | 完美搭档在线观看| 五月婷婷欧美视频| 亚洲人成色777777精品音频| 欧美亚洲视频在线观看| 嫩草一区二区三区| 国产免费人做人爱午夜视频| 日本一区二区视频在线| 伊人22222| 久久亚洲精品国产亚洲老地址| 欧美经典一区| av在线播放亚洲| 国产午夜亚洲精品理论片色戒| 天堂免费在线视频| 久久精品国产一区二区电影| 欧洲美女精品免费观看视频| 看一级黄色录像| av一区二区三区在线| 色老头一区二区| 久久精品一偷一偷国产| 综合激情网...| 欧美v在线观看| 综合婷婷亚洲小说| 免费观看国产精品| 国产成人黄色av| 亚洲精品在线观看91| 挪威xxxx性hd极品| 色88888久久久久久影院按摩| 日本在线免费播放| 国产伦精品一区二区三区视频孕妇 | 国产精品久久久久三级| 99在线无码精品入口| 91精品国产乱码久久久久久久久| 精品72久久久久中文字幕| 99国产精品久久久久久| 亚洲图片一区二区| 国产福利在线看| 99久久无色码| 久久亚洲影院| 久草免费在线视频观看| 亚洲精品一区久久久久久| 国产精品久久久久久av公交车| 成熟丰满熟妇高潮xxxxx视频| 国产欧美日本一区视频| 蜜臀久久99精品久久久| 国产剧情日韩欧美| 在线视频精品| 91在线播放观看| 一区二区日韩精品| 精品按摩偷拍| 国内av一区二区| 欧美性色黄大片| 日本不卡1234视频|