`
shen_xy
  • 浏览: 5559 次
文章分类
社区版块
存档分类
最新评论

浅谈数据结构与构建哈夫曼树

阅读更多
数据结构是什么?一开始听到这个名词的时候,觉得一听就深奥难懂。细细一想,“数据结构”,顾名思义就是数据的结构,是计算机存储数据时用的结构。后来学习这门课,才明白数据结构和效率是密切相关的,编写程序的人要让计算机更加高效的工作,这就涉及到算法。所以我觉得数据结构与算法是密切相关的。
不管是什么语言,似乎学习过程中都有一个必不可少的步骤,就是排序。什么冒泡排序,选择排序,快速排序,堆排序。刚开始总有不解,排序干嘛呢?其实这是检验数据结构和算法最好的例子,如果是一百万个数字,如果用冒泡估计得排上好久了。
不同的排序方法,是用数组,链表,堆栈还是图?这又有不同的效率。所以,我觉得数据结构入门容易,用的得心应手可不是件简单的事情。
前几天写了哈夫曼树。写哈夫曼树,第一步就是读取文件,按字节读取文件,存入到数组队列中;第二步是统计频度,将频度存入另一个数组队列;第三步是对频度进行排序,第四步就是建树了。以下是源代码
/*
* 读文件的方法,将读取到的字节存入数组队列list中
*/
public void readfile() throws IOException{
FileInputStream file = new FileInputStream("file/newtext.txt");
while(file.available()>0){
int i=file.read();
list.add(i);

}
}

/*
* 统计频度的方法,将频度存入另外一个数组队列l中
*/
public void count(){
int count[] = new int[list.size()];
//给数组赋初值为1
for(int i = 0;i<count.length;i++){
count[i]=1;
}
for(int i=0;i<list.size();i++){
for(int j=i+1;j<list.size();j++){
if(list.get(i).equals(list.get(j))){
count[i]++;
list.alter(j, -1);
}
}
for(int m=i+1;m<list.size();m++){
if(list.get(m).equals(-1)){
list.remove(m);
}
}
HaffmanNode node = new HaffmanNode(list.get(i),count[i]);
l.add(node);//将次数存入数组队列中
}

}

/*
* 排序方法,选择排序
*/
public void sort(){
for (int j = 0; j< l.size() - 1; j++) {
for (int t = j + 1; t < l.size(); t++) {
if (l.get(t).getweight() <l.get(j).getweight()) {
l.swap(j, t);
}
}
}

}



/*
* 建树的方法
*/
public void createTree(){
while(l.size()>1){
int temp = l.get(0).getweight()+l.get(1).getweight();
HaffmanNode node = new HaffmanNode(0,temp);
node.setleft(l.get(0));
node.setright(l.get(1));
l.add(node);
l.remove(0);
l.remove(0);
sort();
System.out.println("*"+node.getleft().getweight());
System.out.println("#"+node.getright().getweight());
System.out.println(node.getweight());
}
}

哈夫曼树就建好了,我看了一下别人的,有的用图,有的用链表。我写的确实有些麻烦,办法也不够好,但是都是自己想出来的,还会学习其他办法,使用更高效的方法解决问题。
分享到:
评论

相关推荐

    谈谈关于哈夫曼树及其应用

    ### 浅谈哈夫曼树及其应用 #### 摘要 本文主要介绍哈夫曼树的基本概念及其在多个领域的应用。首先从哈夫曼树的定义和构造算法出发,详细阐述了如何构建哈夫曼树,并重点探讨了哈夫曼树在不同场景下的三种典型应用:...

    浅谈数据结构C++实现中的顺序表与二叉树算法

    内容概要:该资料介绍了多种经典的数据结构与相关的算法。涵盖内容包括但不限于算法复杂度评估、单链表的操作、各类字符串匹配方法(例如Boyer-Moore)、图的各种遍历技术、多种常见的排序技巧(像冒泡排序、快速...

    GUI面板MATLAB直车道线检测.zip

    GUI面板MATLAB直车道线检测

    (2024年更新)八批中国自由贸易试验区明细数据.xlsx

    截至2024年12月,我国已有八批22个自由贸易试验区,73个片区,本次分享的数据包括自贸区名单、自贸区明细、以及自贸区DID的3份数据 一、数据介绍 数据名称:中国自由贸易试验区明细数据 数据范围:八批自由贸易试验区 数据年份:2009-2024年 数据样本:496条 数据来源:政府公开网站 数据整理:内含开放名单、开放网址明细、以及DID数据

    【工程项目】MATLAB车辆检测(速度+平均速度+GUI+车流量+详细注释).zip

    【工程项目】MATLAB车辆检测(速度+平均速度+GUI+车流量+详细注释)

    2023年全国计算机二级C语言程序改错题.pdf

    2023年全国计算机二级C语言程序改错题.pdf

    基于SpringBoot+Vue的MOBA类游戏攻略分享平台(Java毕业设计,包括源码、数据库、教程).zip

    Java 项目, Java 毕业设计,Java 课程设计,基于 SpringBoot 开发的,含有代码注释,新手也可看懂。毕业设计、期末大作业、课程设计、高分必看,下载下来,简单部署,就可以使用。 包含:项目源码、数据库脚本、软件工具等,前后端代码都在里面。 该系统功能完善、界面美观、操作简单、功能齐全、管理便捷,具有很高的实际应用价值。 项目都经过严格调试,确保可以运行! 1. 技术组成 前端:html、javascript、Vue 后台框架:SpringBoot 开发环境:idea 数据库:MySql(建议用 5.7 版本,8.0 有时候会有坑) 数据库工具:navicat 部署环境:Tomcat(建议用 7.x 或者 8.x 版本), maven 2. 部署 如果部署有疑问的话,可以找我咨询 Java工具包下载地址: https://pan.quark.cn/s/eb24351ebac4 后台路径地址:localhost:8080/项目名称/admin/dist/index.html 前台路径地址:localhost:8080/项目名称/front/index.html (无前台不需要输入)

    基于SSM+JSP的社区疫情防控管理信息系统+数据库(Java毕业设计,包括源码,教程).zip

    Java 项目, Java 毕业设计,Java 课程设计,基于 SpringBoot 开发的,含有代码注释,新手也可看懂。毕业设计、期末大作业、课程设计、高分必看,下载下来,简单部署,就可以使用。 包含:项目源码、数据库脚本、软件工具等,前后端代码都在里面。 该系统功能完善、界面美观、操作简单、功能齐全、管理便捷,具有很高的实际应用价值。 项目都经过严格调试,确保可以运行! 1. 技术组成 前端:jsp 后台框架:SSM 开发环境:idea 数据库:MySql(建议用 5.7 版本,8.0 有时候会有坑) 数据库工具:navicat 部署环境:Tomcat(建议用 7.x 或者 8.x 版本), maven 2. 部署 如果部署有疑问的话,可以找我咨询 Java工具包下载地址: https://pan.quark.cn/s/eb24351ebac4

    2023年卫生招聘考试之卫生招聘(计算机信息管理)自测模拟预测题库.pdf

    2023年卫生招聘考试之卫生招聘(计算机信息管理)自测模拟预测题库.pdf

    mysql-5.7.26-winx64 vagrant-2.4.3-windows-amd64 seata-server-2.0.0 nacos-server-2.5.0 VirtualBox-6.1

    mysql-5.7.26-winx64 vagrant-2.4.3-windows-amd64 seata-server-2.0.0 nacos-server-2.5.0 VirtualBox-6.1

    2025年中国企业人才激励现状及发展趋势研究报告

    内容概要:本文是南京蓝腾管理咨询有限公司发布的《2025年中国人才激励白皮书》,聚焦在中国企业管理中人才激励的问题,并结合中国的国情与文化背景,通过对全国18个行业、25个省份、超过千名员工的广泛调查,提出了具有中国特色的管理与激励模式的新思考和解决方案。主要内容涵盖了企业激励措施的现状分析、核心结论、发展趋势预测等方面,其中包括物质和非物质激励、不同层次与年龄的员工激励差异及其对未来企业发展的影响。 适合人群:企业管理层,HR从业者以及对公司管理与文化建设感兴趣的读者。 使用场景及目标:帮助企业管理人员更好地理解不同群体(性别、职位、地域等)员工的具体激励需求,识别并克服现有激励机制中的短板,进而提升整体绩效、增强员工满意度和忠诚度;同时也为企业未来的管理与激励策略制定提供了前瞻性指导。 其他说明:此文档分为免费版和全面版两部分,文中还列举了一些具体的激励实例(如跳海酒馆、西贝等企业的人才激励实践),以及未来研究方向和发展趋势预测等内容。

    Java毕业设计-SpringBoot+Vue的考研资讯平台(附源码,数据库).zip

    Java 项目, Java 毕业设计,Java 课程设计,基于 SpringBoot 开发的,含有代码注释,新手也可看懂。毕业设计、期末大作业、课程设计、高分必看,下载下来,简单部署,就可以使用。 包含:项目源码、数据库脚本、软件工具等,前后端代码都在里面。 该系统功能完善、界面美观、操作简单、功能齐全、管理便捷,具有很高的实际应用价值。 项目都经过严格调试,确保可以运行! 1. 技术组成 前端:html、javascript、Vue 后台框架:SpringBoot 开发环境:idea 数据库:MySql(建议用 5.7 版本,8.0 有时候会有坑) 数据库工具:navicat 部署环境:Tomcat(建议用 7.x 或者 8.x 版本), maven 2. 部署 如果部署有疑问的话,可以找我咨询 Java工具包下载地址: https://pan.quark.cn/s/eb24351ebac4 后台路径地址:localhost:8080/项目名称/admin/dist/index.html 前台路径地址:localhost:8080/项目名称/front/index.html (无前台不需要输入)

    springboot校园在线拍卖系统.zip

    ava项目springboot基于springboot的课程设计,包含源码+数据库+毕业论文

    基于JAVA的机场航班起降与协调管理系统&毕业设计&毕业论文&数据库&演示视频&源代码

    本次项目是设计一个基于JAVA的机场航班起降与协调管理系统。 (1)在经济可行性上来分析的话,该软件是机场内部使用的一个指挥协调软件,属于航空安全投资,本软件开发成本并不高,软件和服务器数据库可以用机场原有的数据库进行开发,比起空难给航空公司造成的损失来说九牛一毛。 (2)在技术可行性上来分析的话,该软件主要运用了Java技术、jQuery-easyui和Mysql数据库技术。Java是到目前来说最稳定的、最可靠的软件开发工具;jQuery-easyui虽然是比较新的前台开发技术,但是他的界面新颖整洁,适合于功能性软件的开发;Mysql数据库也是许多大公司都采用的软件项目开发数据库,不仅稳定而且性能可靠,可以用作本次软件的开发。 (3)在法律可行性上来分析的话,该软件使用的技术都为开源的软件开发工具和语言,虽然Java等开发技术都存在Sun公司的版权问题,但是Java技术是可以免费使用的,没有涉及到法律上的侵权。 (4)在方案可行性上来分析的话,此次软件开发的很大一部分精力都放在了软件的需求分析和设计方面,设计出来的软件可以很好地去实现我们所要完成的软件预先设计的功能。

    GUI面板MATLAB的人脸+指纹融合系统.zip

    GUI面板MATLAB的人脸+指纹融合系统

    2023年全国计算机二级MSoffice高级应用模拟试题资料.pdf

    2023年全国计算机二级MSoffice高级应用模拟试题资料.pdf

    航空航天领域翼型振动与颤振分析的MATLAB仿真程序实现及应用

    内容概要:本文档详细记录了一段用于进行航空器机翼加装挂载(如导弹或其他装备)后的结构动力响应分析,特别是对颤振现象研究的 MATLAB 代码片段。主要内容涵盖初始化几何参数、物性参数以及质量特性等基本信息设定,通过定义多个矩阵(弯曲模式、扭转模式)用以描述系统运动方程的形式表达;采用Theodorsen函数表征气动力特性对于系统稳定性的影响;最终利用模态分析确定临界速度并给出最小颤振速率发生位置的相关讨论与实验数据对比验证。 适合人群:航空航天专业研究人员,工程物理学者及高等院校飞行器设计方向研究生及以上水平的技术爱好者。 使用场景及目标:①理解机翼与附加载体之间的动态交互机制;②掌握利用数学工具进行复杂机械系统的稳定性判断方法;③为实际产品研发提供理论依据和技术支持。 其他说明:文档中的部分内容已被省略以保护原创版权,同时确保敏感算法细节不在未经授权的情况下传播。由于文中涉及到大量的矩阵运算以及高级工程力学概念,请在使用前确认自己拥有足够的前置知识。

    个人用途,用于学习和交流

    个人用途,用于学习和交流

    2023年数模实验报告计算机.pdf

    2023年数模实验报告计算机.pdf

    Java毕业设计-SpringBoot+Vue的基于协同过滤算法商品推荐系统(附源码、数据库、教程).zip

    Java 项目, Java 毕业设计,Java 课程设计,基于 SpringBoot 开发的,含有代码注释,新手也可看懂。毕业设计、期末大作业、课程设计、高分必看,下载下来,简单部署,就可以使用。 包含:项目源码、数据库脚本、软件工具等,前后端代码都在里面。 该系统功能完善、界面美观、操作简单、功能齐全、管理便捷,具有很高的实际应用价值。 项目都经过严格调试,确保可以运行! 1. 技术组成 前端:html、javascript、Vue 后台框架:SpringBoot 开发环境:idea 数据库:MySql(建议用 5.7 版本,8.0 有时候会有坑) 数据库工具:navicat 部署环境:Tomcat(建议用 7.x 或者 8.x 版本), maven 2. 部署 如果部署有疑问的话,可以找我咨询 Java工具包下载地址: https://pan.quark.cn/s/eb24351ebac4 后台路径地址:localhost:8080/项目名称/admin/dist/index.html 前台路径地址:localhost:8080/项目名称/front/index.html (无前台不需要输入)

Global site tag (gtag.js) - Google Analytics