- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 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
您可能关注的文档
- 硕士学位论文-基于PLC的自动点胶机控制系统的研究与实现精选.doc
- 硕士学位论文-五轴数控机床回转轴几何误差辨识及补偿精选.doc
- 硕士学位论文-基于攻击树的多层次入侵检测及其在Linux上的原型精选.doc
- 硕士学位论文-企业进销存管理信息系统的设计与实现精选.doc
- 硕士学位论文-当前高中数学教学中形成性评价存在的问题及对策精选.doc
- 硕士学位论文-基于系统动力学的浙江省可持续发展能力研究精选.doc
- 硕士学位论文-基于WEB的高职院校辅助教学平台之设计精选.doc
- 硕士学位论文-沧州地区武术套路竞赛市场现状与发展对策研究精选.doc
- 硕士学位论文-IT服务管理体系研究及建设--福田汽车IT服务管理分析及应用精选.doc
- 硕士学位论文-基于遗传算法的混合高斯模型在与文本无关的说话人识别中的应用精选.doc
文档评论(0)