算法设计与分析实验报告-哈夫曼编码(含源程序)精选.docVIP

算法设计与分析实验报告-哈夫曼编码(含源程序)精选.doc

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
算法设计与分析实验报告-哈夫曼编码(含源程序)精选

昆明理工大学信息工程与自动化学院学生实验报告 ( 2011 — 2012 学年 第 1 学期 ) 课程名称:算法设计与分析 开课实验室:信自楼机房445 2011 年11月 2日 年级、专业、班 计科092 学号 1 姓名 刘召 成绩 实验项目名称 哈夫曼编码 指导教师 张晶 教师评语 该同学是否了解实验原理: A.了解□ B.基本了解□ C.不了解□ 该同学的实验能力: A.强 □ B.中等 □ C.差 □ 该同学的实验是否达到要求: A.达到□ B.基本达到□ C.未达到□ 实验报告是否规范: A.规范□ B.基本规范□ C.不规范□ 实验过程是否详细记录: A.详细□ B.一般 □ C.没有 □ 教师签名: 年 月 日 一、上机目的及内容 1.上机内容 设需要编码的字符集为{d1, d2, …, dn},它们出现的频率为{w1, w2, …, wn},应用哈夫曼树构造最短的不等长编码方案。 2.上机目的 (1)了解前缀编码的概念,理解数据压缩的基本方法; (2)掌握最优子结构性质的证明方法; (3)掌握贪心法的设计思想并能熟练运用。 二、实验原理及基本技术路线图(方框原理图或程序流程图) (1)证明哈夫曼树满足最优子结构性质; 证明:设C为一给定的字母表,其中每个字母c∈C都定义有频度f[c]。设x和y是C中具有最低频度的两个字母。并设D为字母表移去x和y,再加上新字符z后的字母表,D=C-{x,y}∪{z};如C一样为D定义f,其中f[z]=f[x]+f[y]。设T为表示字母表D上最优前缀编码的任意一棵树。那么,将T中的叶子节点z替换成具有x和y孩子的内部节点所得到的树T,表示字母表C上的一个最优前缀编码。 设计贪心算法求解哈夫曼编码方案; 解:哈弗曼编码是以贪心法为基础的,可以从最优子结构中求得问题的解。所以,需要从一个问题中选出一个当前最优的解,再把这些解加起来就是最终问题的解。可以构造一个优先队列priority_queue,每次求解子问题的解时,从优先级队列priority_queue中选取频率最小的两个字母(x、y)进行合并得到一个新的结点z,把x与y从优先级队列priority_queue中弹出,把压入到优先级队列priority_queue中。如此反复进行,直到优先级队列priority_queue中只有一个元素(根节点)为止。 设计测试数据,写出程序文档。 共设计了两组测试数据,他们的哈弗曼树如下图所示: 图(1)测试数据的哈弗曼树图 表一:第一组测试数据 字符 出现的频率 a 1 b 3 c 6 d 14 e 58 表二:第二组测试数据 字符 出现的频率 d 4 b 3 f 5 g 6 h 14 m 16 由图(1)可知各个字符的哈弗曼编码如下表: 表三:表一中各元素的哈弗曼编码 字符 出现的频率 a 0000 b 0001 c 001 d 01 e 1 表四:表二中各元素的哈弗曼编码 字符 出现的频率 d 001 b 000 f 010 g 011 h 10 m 11 三、所用仪器、材料(设备名称、型号、规格等或使用软件) 1台PC及VISUAL C++6.0软件 亿图程序流程图绘制软件 四、实验方法、步骤(或:程序代码或操作过程) 下面源代码可以在Visual C++6.0平台上运行! //author@刘召 at 2011-11-18 //This program is edited and compiled on Visual Studio 10 platform //Huffman编码 //#include stdafx.h//在Visual studio中运行,应取消该句的注释! #include iostream #include queue #include vector #include iomanip #include string #includecctype using namespace std; struct codeInformation{ double priority; char codeName; int lchild,rchild,parent;bool test; bool operator (const codeInformation x) const {return !(priorityx.pr

您可能关注的文档

文档评论(0)

feixiang2017 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档