Java学习者论坛

 找回密码
 立即注册

QQ登录

只需一步,快速开始

手机号码,快捷登录

恭喜Java学习者论坛(https://www.javaxxz.com)已经为数万Java学习者服务超过8年了!积累会员资料超过10000G+
成为本站VIP会员,下载本站10000G+会员资源,购买链接:点击进入购买VIP会员
JAVA高级面试进阶视频教程Java架构师系统进阶VIP课程

分布式高可用全栈开发微服务教程

Go语言视频零基础入门到精通

Java架构师3期(课件+源码)

Java开发全终端实战租房项目视频教程

SpringBoot2.X入门到高级使用教程

大数据培训第六期全套视频教程

深度学习(CNN RNN GAN)算法原理

Java亿级流量电商系统视频教程

互联网架构师视频教程

年薪50万Spark2.0从入门到精通

年薪50万!人工智能学习路线教程

年薪50万!大数据从入门到精通学习路线年薪50万!机器学习入门到精通视频教程
仿小米商城类app和小程序视频教程深度学习数据分析基础到实战最新黑马javaEE2.1就业课程从 0到JVM实战高手教程 MySQL入门到精通教程
查看: 287|回复: 0

[JavaIO学习]一个哈夫曼压缩与解压缩程序

[复制链接]
  • TA的每日心情
    开心
    2021-3-12 23:18
  • 签到天数: 2 天

    [LV.1]初来乍到

    发表于 2014-11-3 23:58:26 | 显示全部楼层 |阅读模式
    一个哈夫曼压缩与解压缩程序,能正常解压与压缩,但解压时间较长,有待改进.
    1. import java.util.ArrayDeque;     
    2. import java.util.ArrayList;     
    3. import java.util.Collections;     
    4. import java.util.List;     
    5. import java.util.Queue;
    6. import java.util.HashMap;
    7. import java.util.Map;
    8. import java.util.Iterator;
    9.      
    10. public class HuffmanTree< T> {   
    11.         //创建一个Map存放字符与码表的键值对,即码表
    12.         private java.util.HashMap< T,String > map=new HashMap< T, String>();
    13.         //创建一个队列存放关键码
    14.         private List< T> list = new ArrayList < T> ();
    15.        
    16.         public HashMap< T, String> getMap() {
    17.                 return map;
    18.         }
    19.         public void setMap(HashMap< T, String> map) {
    20.                 this.map = map;
    21.         }
    22.         public List< T> getList() {
    23.                 return list;
    24.         }
    25.         public void setList(List
    26.    
    27.       list) {
    28.                 this.list = list;
    29.         }
    30.          /**
    31.          * 由节点队列创建哈夫曼树
    32.          *
    33.          * @param nodes
    34.          *            :传入的队列
    35.          * @return:哈夫曼树的节点
    36.          */
    37.       
    38.   
    39.     public   Node< T> createTree(List< Node< T>> nodes){     
    40.         while(nodes.size() > 1){     
    41.             Collections.sort(nodes);     
    42.             Node< T> left = nodes.get(nodes.size()-1);     
    43.             Node< T> right = nodes.get(nodes.size()-2);     
    44.             Node< T> parent = new Node
    45.      
    46.       (null, left.getWeight()+right.getWeight());     
    47.             parent.setLeft(left);     
    48.             parent.setRight(right);     
    49.             nodes.remove(left);     
    50.             nodes.remove(right);     
    51.             nodes.add(parent);     
    52.         }     
    53.         return nodes.get(0);         
    54.     }     
    55.   
    56.       
    57.         /**
    58.          * 创建哈夫曼编码
    59.          * @param root
    60.          * @param hfmCode
    61.          */
    62.         public  void createHfmCode(Node< T> root, String hfmCode) {
    63.       
    64.           if (root != null) {
    65.             if (root.getLeft() == null) {
    66.                 //System.out.println(root.getData());
    67.                 //System.out.println("该节点的哈夫曼编码:" + hfmCode);       
    68.                 //将指定的值与此映射中的指定键关联,即将T与它的哈夫曼编码一一对应存放进Map
    69.                 map.put(root.getData(), hfmCode);
    70.                 //将根节点的字符即Map的关键码存放进队列
    71.                 list.add(root.getData());
    72.             }
    73.         createHfmCode(root.getLeft(),hfmCode+"0");   
    74.         createHfmCode(root.getRight(),hfmCode+"1");   
    75.        }
    76.      }   
    77.         /**
    78.          * 打印输出哈夫曼编码
    79.          * @param root
    80.          * @param hfmCode
    81.          */
    82.         public void printHuffman(Node< T> root, String hfmCode) {
    83.         
    84.          Iterator< Map.Entry< T,String>> iter = map.entrySet().iterator();
    85.         
    86.          while (iter.hasNext()) {
    87.             Map.Entry< T,String> entry =iter.next();
    88.                T t=entry.getKey();
    89.                String  val = entry.getValue();
    90.               System.out.println(t.toString()+"-->"+val);
    91.             
    92.           }
    93.          /*if (root != null) {
    94.                        
    95.             if (root.getLeft() == null) {
    96.                  //打印叶节点的相关信息
    97.                 System.out.println(root.getData());
    98.                 System.out.println("该叶节点的权值:" + root.getWeight());
    99.                 System.out.println("该节点的哈夫曼编码:" + hfmCode);                                                       
    100.              }
    101.                 Node
    102.       
    103.         lNode = root.getLeft();
    104.                 printHuffman(lNode, hfmCode + "0");
    105.                 Node
    106.       
    107.          rNode = root.getRight();
    108.                 printHuffman(rNode, hfmCode + "1");
    109.           }*/
    110.         }
    111.          
    112.     public static < T> List< Node< T>> breadth(Node< T> root){  //广度优先遍历哈夫曼树   
    113.         List< Node< T>> list = new ArrayList< Node< T>>();     
    114.         Queue< Node< T>> queue = new ArrayDeque< Node< T>>();     
    115.             
    116.         if(root != null){     
    117.             queue.offer(root);     
    118.         }     
    119.             
    120.         while(!queue.isEmpty()){     
    121.             list.add(queue.peek());     
    122.             Node
    123.         
    124.           node = queue.poll();     
    125.                  
    126.             if(node.getLeft() != null){     
    127.                 queue.offer(node.getLeft());     
    128.             }     
    129.                  
    130.             if(node.getRight() != null){     
    131.                 queue.offer(node.getRight());     
    132.             }     
    133.         }     
    134.         return list;     
    135.     }     
    136. }   
    137.         
    138.       
    139.       
    140.      
    141.    
    复制代码
    其它程序请下载.

       
         
         
          
          

            
          

            
          
         
       

      


    源码下载:http://file.javaxxz.com/2014/11/3/235826281.zip
    回复

    使用道具 举报

    您需要登录后才可以回帖 登录 | 立即注册

    本版积分规则

    QQ|手机版|Java学习者论坛 ( 声明:本站资料整理自互联网,用于Java学习者交流学习使用,对资料版权不负任何法律责任,若有侵权请及时联系客服屏蔽删除 )

    GMT+8, 2025-2-25 14:10 , Processed in 0.334322 second(s), 35 queries .

    Powered by Discuz! X3.4

    © 2001-2017 Comsenz Inc.

    快速回复 返回顶部 返回列表