ImageVerifierCode 换一换
格式:DOCX , 页数:17 ,大小:106.99KB ,
资源ID:7623428      下载积分:3 金币
快捷下载
登录下载
邮箱/手机:
温馨提示:
快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。 如填写123,账号就是123,密码也是123。
特别说明:
请自助下载,系统不会自动发送文件的哦; 如果您已付费,想二次下载,请登录后访问:我的下载记录
支付方式: 支付宝    微信支付   
验证码:   换一换

加入VIP,免费下载
 

温馨提示:由于个人手机设置不同,如果发现不能下载,请复制以下地址【https://www.bdocx.com/down/7623428.html】到电脑端继续下载(重复下载不扣费)。

已注册用户请登录:
账号:
密码:
验证码:   换一换
  忘记密码?
三方登录: 微信登录   QQ登录  

下载须知

1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。
2: 试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。
3: 文件的所有权益归上传用户所有。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 本站仅提供交流平台,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

版权提示 | 免责声明

本文(构造哈夫曼树.docx)为本站会员(b****6)主动上传,冰豆网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知冰豆网(发送邮件至service@bdocx.com或直接QQ联系客服),我们立即给予删除!

构造哈夫曼树.docx

1、构造哈夫曼树西安文理学院软件学院课程设计报告设计名称: 数据结构课程设计 设计题目: 构造哈夫曼树的哈夫曼算法 学生学号: 1402120138 专业班级: 12级1班 学生姓名: 周欣 学生成绩: 指导教师(职称): 韩利凯(教授) 课题工作时间: 2014.6.16 至 2014.6.27 软件学院课程设计任务书学生姓名周欣学号1402120138专业班级1班设计题目构造哈夫曼树的哈夫曼算法内容概要: 设计或开发环境:Microsoft Visual Studio 2010 关键技术:C语言 主要功能:能求解出所构造的哈夫曼树的带权路径长度。文献资料:1严蔚敏 吴伟民编.数据结构(c语言版

2、). 清华大学出版社,2010.92 韩利凯,李军.数据结构 浙江大学出版社 M 2013.83谭浩强编.C程序设计.清华大学出版社 2010.6设计要求:(1)可以使用实验工具的有关功能。(2)要能演示构造过程。(3)求解出所构造的哈夫曼树的带权路径长度。工作期限:设计工作自2014年6月16日至2014年6月27日止。指导教师: 韩利凯 院长: 日 期:2014年6月16日软件学院课程设计进度安排表学生姓名: 学号: 专业: 班级: 起止日期内 容备注6月16日 6月 17日下任务书;收集、阅读、整理相关参考文献,并进行归纳和概括总结,完成项目/任务背景介绍部分文字内容。6月18日11月2

3、0日系统功能设计和模块设计、系统体系结构构建。6月21日6月24日各功能模块编码实现,系统各功能模块调试与维护。6月25日6月26日系统功能集成、系统调试与测试,按照模板要求撰写课程设计/项目设计报告。6月27日课程设计/项目设计分组答辩,提交课程设计/项目设计报告以及相关文档,进行成绩评定。指导教师签名: 2014年6月16日成绩评定表学生姓名: 周欣 学号: 1402120138 专业: 软件工程 班级: 1班 类别合计分值各项分值评分标准实际得分合计得分平时表现1010按时参加设计指导,无违反纪律情况。完成情况3020按设计任务书的要求完成了全部任务,能完整演示其设计内容,符合要求。10

4、能对其设计内容进行详细、完整的介绍,并能就指导教师提出的问题进行正确的回答。报告质量3510报告文字通顺,内容翔实,论述充分、完整,立论正确,结构严谨合理;报告字数符合相关要求,工整规范,整齐划一。5课题背景介绍清楚,综述分析充分。5设计方案合理、可行,论证严谨,逻辑性强,具有说服力。5符号统一;图表完备、符合规范要求。5能对整个设计过程进行全面的总结,得出有价值的结论或结果。5参考文献数量在2篇以上,格式符合要求,在正文中正确引用。答辩情况2510在规定时间内能就所设计的内容进行阐述,言简意明,重点突出,论点正确,条理清晰。15在规定时间内能准确、完整、流利地回答教师所提出的问题。总评成绩:

5、 分 指导教师: (签字) 日期:2014 年6月 27 日摘 要 摘要: 设计程序以实现构造哈夫曼树的哈夫曼算法,该程序的目的是求解出所构造的哈夫曼树的带权路径长度。利用哈夫曼树的结构,求出指令的哈夫曼代码,同时求出叶子节点的带权路径长度。依次输入五个值分别算出其权值,最后输出所构造的哈夫曼树的带权路径长度。 关键词:数组;带权路径长度;结点.目 录摘 要 v目 录 I第一章 课题背景 21.1 课题背景 21.11课题背景知识 21.2课题目的与意义 21.2.1课题的目的 21.2.2课题意义 2第二章 设计简介及设计方案论述 32.1 系统分析 32.1.1 功能需求 32.1.2 数

6、据需求 32.1.3 系统需求 32.2 主要难点 3第三章 详细设计 43.1 程序结构分析 43.1.1 图示 43.1.2程序模块设计 4第四章 设计结果及分析 74.1 程序运行结果 74.1.1 截图 74.2运行结果分析 74.2.1测试 7总结 8参考文献 9附录 10第一章 课题背景1.1 课题背景1.11课题背景知识 在实际生活和生产应用中,我们往往会遇到综合比较一系列的离散量的问题;比如说车站根据包裹的重量以及旅途的长短来确定携带行李的价格,或者我们根据一定的重量范围来给一箱铁球进行分类。我们说在现实的分类中,每一类数据出现的概率不尽相同;这些数据出现的概率可以被看做哈夫曼

7、树中叶子的权值。为了获取最短的路径,也就是带权路径长度最短的二叉树,我们希望那些权值低的数据拥有相对较长的对根结点的路径长度。1.2课题目的与意义 1.2.1课题的目的 本课题的目的是让同学们理解哈夫曼算法,并能利用自己已经学习的知识,去解决一些现实生活中出现的问题。比如各个城市之间需要联网问题,利用哈夫曼树的相关知识就能对这一问题作出很好的解决。1.2.2课题意义 一个好的算法可以更快的解决问题,所以平时在学习编程的时候应该着重理解一些基础的算法。 第二章 设计简介及设计方案论述2.1 系统分析2.1.1 功能需求(1)可以使用实验工具的有关功能。(2)要能演示构造过程。(3)求解出所构造的

8、哈夫曼树的带权路径长度。2.1.2 数据需求在输入过程中,首先要给定输入的数据,数据只能是数字,不能是字母或其他,不能连续输入数据,必须要求以换行分开要输入的数据。2.1.3 系统需求 系统必须安全可靠,不会出现无故死机状态,本程序较小,系统可以正常运行即可。2.2 主要难点(1)构造哈夫曼树:根据给定的权值构成二叉树集合,其中每棵二叉树中只有一个带权的根节点,其左右子树均为空;在二叉树集合中选取两棵根节点权值最小的树作为左右子树构造一棵新的二叉树,且新的二叉树的根节点的权值为其左、右子树上根节点的权值之和;在二叉树集合中删除这两棵树,并将得到的二叉树加入集合中;重复上述步骤,直至二叉树集合中

9、只含一棵树为止。(2)求带权路径长度:先求每个叶子结点到树根之间的路径长度与该叶子结点所带权值之积,在将所得之积求和。 第三章 详细设计3.1 程序结构分析3.1.1 图示 3-1函数流程图3.1.2程序模块设计1)建立叶结点个数为n权值为weight的哈夫曼树haffTreevoid Haffman(int weight, int n, HaffNode haffTree) int j, m1, m2, x1, x2; /哈夫曼树haffTree初始化。n个叶结点的哈夫曼树共有2n-1个结点 for(int i=0;i2*n-1;i+) if(in) haffTreei.weight=wei

10、ghti; else haffTreei.weight=0; haffTreei.parent=0; haffTreei.flag=0; haffTreei.leftChild=-1; haffTreei.rightChild=-1; /构造哈夫曼树haffTree的n-1个非叶结点 2) 将找出的两棵权值最小的子树合并为一棵子树 for(int k=0;kn-1;k+) m1=m2=MaxValue; x1=x2=0; for(j=0;jn+k;j+) if (haffTreej.weight m1 & haffTreej.flag = 0) m2=m1; x2=x1; m1=haffTre

11、ej.weight; x1=j; else if(haffTreej.weight m2 & haffTreej.flag = 0) m2 = haffTreej.weight; x2 = j; 3)由n个结点的哈夫曼树haffTree构造哈夫曼编码haffCode void HaffmanCode(HaffNode haffTree, int n, Code haffCode) Code *cd = new Code; int child, parent; /求n个叶结点的哈夫曼编码 for(int i=0;istart=n-1; /不等长编码的最后一位为n-1 cd-weight=haff

12、Treei.weight; /取得编码对应权值的字符 child=i; parent=haffTreechild.parent; /由叶结点向上直到根结点 while(parent!=0) if(haffTreeparent.leftChild = child) cd-bitcd-start = 0; /左孩子结点编码0 else cd-bitcd-start = 1; /右孩子结点编码1 cd-start-; child=parent; parent=haffTreechild.parent; /保存叶结点的编码和不等长编码的起始位 for(int j=cd-start+1;jbitj; h

13、affCodei.start=cd-start; haffCodei.weight=cd-weight; /保存编码对应的权值 第四章 设计结果及分析4.1 程序运行结果4.1.1 截图4.2运行结果分析 该运行结果为输入了五个结点的权值之后所得到的哈夫曼编码和所得到的带权路径长度,通过本次试验我更好地了解了哈夫曼树的结构,知道了最优二树的优点与实际应用,学会了怎么求哈夫曼树的带权路径长度。 4.2.1测试 软件测试是软件生存期中的一个重要阶段,是软件质量保证的关键步骤从用户的角度来看,普遍希望通过软件测试暴露软件中隐藏的错误和缺陷,所以软件测试应该是“为了发现错误而执行程序的过程”。或者说,

14、软件测试应该根据软件开发各阶段的规格说明和程序的内部结构而精心设计一批测试用例(即输入数据及其预期的输出结果),并利用这些测试用例去运行程序,以发现程序错误或缺陷。过度测试则会浪费许多宝贵的资源。到测试后期,即使找到了错误,然而付出了过高的代价。 总结 在我自己课程设计中,就在编写好源代码后的调试中出现了不少的错误,遇到了很多麻烦及困难,我的调试及其中的错误和我最终找出错误,修改为正确的能够执行的程序中,通过分析,我学到了:在定义头文件时可多不可少,即我们可多写些头文件,肯定不会出错,但是若没有定义所引用的相关头文件,必定调试不通过;在这次课程设计中我学习了很多在上课没懂的知识,并对求哈夫曼树

15、的算法有了更加深刻的了解,更巩固了课堂中学习有关于哈夫曼编树的知识,真正学会了一种算法。当求解一个算法时,不是拿到问题就不加思索地做,而是首先要先对它有个大概的了解,接着再详细地分析每一步怎么做,无论自己以前是否有处理过相似的问题,只要按照以上的步骤,必定会顺利地做出来。通过本次数据结构的课程设计,虽然程序运行结果基本正确,能实现实验要求的功能,但也存在不足的地方,如运行界面不美观,程序语句不精练,有些地方可以更加简单等等。这些都需要我在以后的实验中着重注意并加以学习,另外,这次实验编程我花的时间较短,因为学期末复习工作比较忙,所以本程序还有一些不足之处。 参考文献1严蔚敏 吴伟民编.数据结构

16、(c语言版). 清华大学出版社,2010.92 韩利凯,李军.数据结构 浙江大学出版社 M 2013.83谭浩强编.C程序设计.清华大学出版社 2010.64 唐国民,王国均. 数据结构(C语言版)M. 北京:清华大学出版社.5 王路明. C语言程序设计教程M. 北京:北京邮电大学出版社,2005年5月.6 谭浩强. C+程序设计M. 北京:清华大学出版社.2004.7范策. 算法与数据结构(C语言版)M. 北京:机械工业出版社,2004.8 詹春华,杨沙. C语言程序设计教程M. 科学出版社,2011.8.附录 #include #include #includeconst int MaxV

17、alue = 1000; /初始设定的权值最大值const int MaxBit = 4; /初始设定的最大编码位数const int MaxN = 10; /初始设定的最大结点个数struct HaffNode /哈夫曼树的结点结构 int weight; /权值 int flag; /标记 int parent; /双亲结点下标 int leftChild; /左孩子下标 int rightChild; /右孩子下标; struct Code /存放哈夫曼编码的数据元素结构 int bitMaxN; /数组 int start; /编码的起始下标 int weight; /字符的权值;vo

18、id Haffman(int weight, int n, HaffNode haffTree) /建立叶结点个数为n权值为weight的哈夫曼树haffTree int j, m1, m2, x1, x2; /哈夫曼树haffTree初始化。n个叶结点的哈夫曼树共有2n-1个结点 for(int i=0;i2*n-1;i+) if(in) haffTreei.weight=weighti; else haffTreei.weight=0; haffTreei.parent=0; haffTreei.flag=0; haffTreei.leftChild=-1; haffTreei.right

19、Child=-1; /构造哈夫曼树haffTree的n-1个非叶结点 for(int k=0;kn-1;k+) m1=m2=MaxValue; x1=x2=0; for(j=0;jn+k;j+) if (haffTreej.weight m1 & haffTreej.flag = 0) m2=m1; x2=x1; m1=haffTreej.weight; x1=j; else if(haffTreej.weight m2 & haffTreej.flag = 0) m2 = haffTreej.weight; x2 = j; /将找出的两棵权值最小的子树合并为一棵子树 haffTreex1.p

20、arent = n+k; haffTreex2.parent = n+k; haffTreex1.flag = 1; haffTreex2.flag = 1; haffTreen+k.weight = haffTreex1.weight+haffTreex2.weight; haffTreen+k.leftChild = x1; haffTreen+k.rightChild = x2; void HaffmanCode(HaffNode haffTree, int n, Code haffCode) /由n个结点的哈夫曼树haffTree构造哈夫曼编码haffCode Code *cd = n

21、ew Code; int child, parent; /求n个叶结点的哈夫曼编码 for(int i=0;istart=n-1; /不等长编码的最后一位为n-1 cd-weight=haffTreei.weight; /取得编码对应权值的字符 child=i; parent=haffTreechild.parent; /由叶结点向上直到根结点 while(parent!=0) if(haffTreeparent.leftChild = child) cd-bitcd-start = 1; /左孩子结点编码0 else cd-bitcd-start = 0; /右孩子结点编码1 cd-star

22、t-; child=parent; parent=haffTreechild.parent; /保存叶结点的编码和不等长编码的起始位 for(int j=cd-start+1;jbitj; haffCodei.start=cd-start; haffCodei.weight=cd-weight; /保存编码对应的权值 int main() coutn; cout 请依次输入各权值; int i, j, n=5,sum=0,l=0; int weight5; for(int k=0;kweightk; HaffNode *myHaffTree = new HaffNode2*n+1; Code

23、*myHaffCode = new Coden; if(n MaxN) cout 定义的n越界,修改MaxN! endl; exit(0); Haffman(weight, n, myHaffTree); HaffmanCode(myHaffTree, n, myHaffCode); /输出每个叶结点的哈夫曼编码 for(i=0;in;i+) coutWeight=myHaffCodei.weight Code=; for(j=myHaffCodei.start+1;jn;j+) coutmyHaffCodei.bitj;l+;/coutmyHaffCodei.start; cout=0 & myHaffCodei.*bitj/10=1 & myHaffCodei.bitj/10=10 & myHaffCodei.bitj/10=100 & myHaffCodei.bitj/10=1000 & myHaffCodei.bitj/1010000) l=5;sum=sum+myHaffCodei.weight*l; else*/ cout带权路径长度=sumendl; return 0;

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1