- 1、本文档共26页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
哈夫曼编码设计与实现1
华北科技学院计算机学院开放实验
实 验 报 告
实验名称 哈夫曼树编码的设计与实现
实验学期 2014 至 2015 学年 第 一 学期
学生所在系部 计算机学院
年级 2013 专业班级 软件工程B13-2班
学生姓名 扈鹏程 学号 201307044213
任课教师 栾尚敏
实验成绩
计算机学院制
《哈夫曼树编码的设计与实现》开放实验报告
开课实验室:基础(二) 年 月 日
实验题目
哈夫曼树编码的设计与实现
一、实验目的
设计哈夫曼树编码系统,锻炼学生的编程能力,巩固哈夫曼算法,熟悉遍历方法。
二、设备与环境
Windows Xp,VC6.0
三、实验内容
(1)原理分析:
编写此系统是为了实现一个利用哈夫曼算法的编码和译码系统。比如,在利用电报通讯时,需要将文字转换成有二进制的字符组成的字符串。比如需要传送的电文为“A B D C C D A”假设将A,B,C,D分别编码为00,10,10,11。则上述电文便为00011110101100,总长14位。但是在传送过程中,总希望长度能够尽可能的短,于是我们想采用长度不等的代码。但是这种编码必须遵循:任何一个字符的编码都不是另一个字符编码的前缀。
哈夫曼编码恰好可以很好的解决前缀码这一问题。在使用哈夫曼编码时,它会根据结点权值进行,对于使用频率低的字符,会将其置于树层次比较高的地方;相反的是使用频率高的字符。这样做的结果就是使使用频率高的字符编码变得很短而使用频率低的字符编码长一些,而编码长度一般取决于使用频率高的字符,因此这样可以大大缩短字符编码长度,并且不易被别人获取编码规则。
运用哈夫曼编码最重要的一点就是建立哈夫曼树,而对于树这种非线性结构,使用链式存储有着多种优势:节省内存空间,因为它不会存在多申请存储空间的情况;同时,指针可以清晰的指示各结点之间的关系,不像顺序存储那样需要进行复杂的逻辑设计;
算法设计:采用逐步求精的方法,给出从自然语言描述的算法到类C语言描述的算法;
= 1 \* GB3 \* MERGEFORMAT ①初始化哈夫曼树
建立链表,若链表已存在,则销毁原链表,重新建立,用以存储符号及权值。由文件中逐个读取字符,并在链表中查找,找到则权值加1,否则为其新建结点,并赋其权值为1。
类C描述:
void new(Linklist *head)
{
if(head!=NULL) destory(head);
p=head-next;
while(fp!=EOF)
{
c=getc(fp);
while(p!=NULL i==0)
{
if(c=p-c) {p-w++;i++}
p0=p;p=p-next;
}
if(p==NULL)
{
q=Linklist * malloc(space);
q-c=c;q-w=1;p0-next=p;
}
c=getc(fp);
}
}
建立哈夫曼树。
= 1 \* ROMAN \* MERGEFORMAT I 在1)建立的链表中,挑选出未标记且权值最小的结点,将其移动至第一个结点位置,并且进行标记,并且重复次操作一次;
= 2 \* ROMAN \* MERGEFORMAT II 新建结点为这两个结点的父节点,并取代这两个结点在链表中的位置,其权值为两个子节点权值之和;
= 3 \* ROMAN \* MERGEFORMAT III 回到步骤 = 1 \* ROMAN \* MERGEFORMAT I,直至链表中除头外仅剩一个结点。
类C描述:
void init(Linklist *head)
{
while(n1)
{
search(head);search(head);
q=Linklist * malloc(space);
q-rchild=head-next-next;
q-lchild=head-next;
q-c=’\0’;
q-lchild-parent=q-rchild-parent=q;
q-w=q-lchild-w+q-rlchild-w;
q-next=q-rchild-next;
head-next=q;
n--;
}
}
= 2 \* GB3 \*
您可能关注的文档
- 中国特色社会主义理论体系多选练习题与模拟试题.doc
- 中国稀土资源出口贸易摩擦与应对措施.doc
- 中国餐饮行业形势与发展趋势预测.ppt
- 中国邮政便民服务站安装指南与常见故障解决办法.ppt
- 中学数学教学反思意义与作用.doc
- 中小企业网站营销与网站规划方案.doc
- 中层干部管理职责与执行技巧.ppt
- 中山大学化工原理 第1章和第2章习题课.ppt
- 中图版必修3第一章第一节.ppt
- 中星睿典2012年最新职称计算机Dreamweaver MX模块练习试题.doc
- 北师大版(2024)八年级数学上册课件 3.2 平面直角坐标系 第2课时 点的坐标特征.pptx
- 北师大版(2024)八年级数学上册课件 3.2 平面直角坐标系 第3课时 建立适当的平面直角坐标系.pptx
- 北师大版(2024)八年级数学上册课件 4.3 一次函数的图象 第1课时 正比例函数的图象及性质.pptx
- (人教A版数学选择性必修三)讲义第15讲7.1.1条件概率(学生版+解析).docx
- (人教A版数学选择性必修三)讲义第19讲8.1成对数据的统计相关性(8.1.1变量的相关关系+8.1.2样本相关系数)(学生版+解析).docx
- 北师大版(2024)八年级数学上册课件 5.2 二元一次方程组的解法 第2课时 加减消元法.pptx
- (人教A版数学选择性必修一)2025年秋季学期讲义第01讲1.1.1空间向量及其线性运算(学生版+教师版).docx
- 北师大版(2024)八年级数学上册课件 5.2 二元一次方程组的解法 第1课时 代入消元法.pptx
- 北师大版(2024)八年级数学上册课件 5.3 二元一次方程组的应用 第3课时 二元一次方程组的应用(3).pptx
- 北师大版(2024)八年级数学上册课件 5.4 二元一次方程与一次函数 第2课时 用二元一次方程组确定一次函数表达式.pptx
文档评论(0)