java中霍夫曼树的示例分析
发表于:2025-01-17 作者:千家信息网编辑
千家信息网最后更新 2025年01月17日,这篇文章主要介绍了java中霍夫曼树的示例分析,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。霍夫曼树一、基本介绍二、霍夫曼树几个重要概
千家信息网最后更新 2025年01月17日java中霍夫曼树的示例分析
这篇文章主要介绍了java中霍夫曼树的示例分析,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。
霍夫曼树
一、基本介绍
二、霍夫曼树几个重要概念和举例说明
构成霍夫曼树的步骤
举例:以arr = {1 3 6 7 8 13 29}
public class HuffmanTree { public static void main(String[] args) { int[] arr = { 13, 7, 8, 3, 29, 6, 1 }; Node root = createHuffmanTree(arr); preOrder(root); } // 编写一个前序遍历的方法 public static void preOrder(Node root) { if (root != null) { root.preOrder(); } else { System.out.println("树是空树,无法遍历~~"); } } // 创建赫夫曼树的方法 /** * @param arr 需要创建成霍夫曼树的数组 * @return 创建好后的霍夫曼树的root节点 */ public static Node createHuffmanTree(int[] arr) { // 第一步为了操作方便 // 1.遍历 arr 数组 // 2.将 arr 的每个元素构成一个Node // 3.将Node 放入到ArrayList中 Listnodes = new ArrayList (); for (int value : arr) { nodes.add(new Node(value)); } while (nodes.size() > 1) { // 排序从小到大 Collections.sort(nodes); System.out.println("nodes = " + nodes); // 取出根节点权值最小的两颗二叉树 //注意:如果是从大到小排列的:就应该取倒数第一个和倒数第二个 // (1) 取出权值最小的节点(二叉树) Node leftNode = nodes.get(0); // (2) 取出权值第二小的节点(二叉树) Node rightNode = nodes.get(1); // (3) 构建一颗新的二叉树 Node parent = new Node(leftNode.value + rightNode.value); parent.left = leftNode; parent.right = rightNode; // (4) 从ArrayList删除处理过的二叉树 nodes.remove(leftNode); nodes.remove(rightNode); // (5) 将parent加入到nodes nodes.add(parent); } // 返回赫夫曼树的root节点 return nodes.get(0); }}//创建节点类//为了让Node对象支持排序Collections集合排序//让Node实现Comparable接口class Node implements Comparable { int value;// 节点权值 Node left;// 指向左子节点 Node right;// 指向右子节点 public Node(int value) { this.value = value; } // 写一个前序遍历 public void preOrder() { System.out.println(this); if (this.left != null) { this.left.preOrder(); } if (this.right != null) { this.right.preOrder(); } } @Override public String toString() { return "Node [value=" + value + "]"; } @Override public int compareTo(Node o) { // 表示从小到大排列 return this.value - o.value; }}
霍夫曼编码
一、基本介绍
二、原理剖析
6)说明:
原来长度是359,压缩了(359 - 133) / 359 = 62.9%
此编码满足前缀编码,即字符的编码都不能是其他字符编码的前缀。不会造成匹配的多义性;
霍夫曼编码是无损的压缩处理方案
注意:
霍夫曼编码压缩文件注意事项
1)如果文件本身就是经过压缩处理的,那么使用赫夫曼编码在压缩效率不会有明显变化,比如视频,ppt等等文件
2)赫夫曼编码是按字节来处理的,因此可以处理所有的文件(二进制文件、文本文件)
3)如果一个文件中的内容,重复的数据不多,压缩效果也不会很明显。
感谢你能够认真阅读完这篇文章,希望小编分享的"java中霍夫曼树的示例分析"这篇文章对大家有帮助,同时也希望大家多多支持,关注行业资讯频道,更多相关知识等着你来学习!
霍夫
霍夫曼
编码
节点
文件
处理
篇文章
赫夫
赫夫曼
排序
示例
分析
明显
最小
从小到大
从小
前缀
字符
指向
数组
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
网络安全本质在于
数据库查询递归怎么解决
数据库时间与系统时间
客户怎么找软件开发商
乡镇网络安全保障工作机制
合肥企业网络技术咨询哪家好
微机室不用服务器行不行
生物信息学与网络安全研究生
长沙网律互联网科技公司
提高数据库质量的方法
输入设备口令显示访问数据库错误
建设用地减量数据库
访问网页无法认证服务器
百度云服务器安全组开端口
怎样攻击网吧服务器
保亿家互联网科技有限公司
使用t-sql还原数据库
服务器的安装总结
软件开发有税率返还吗
数据库技术发展经历了三个阶段
软件开发公司 上海
宁乡安卓软件开发培训
主域名服务器是什么
数据库 教材 经典
流媒体管理服务器配置要求
ro 检查服务器
烽火服务器怎么格式化
网络安全五进宣传
javs项目数据库适配
软件开发管理工具分类