- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、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,否则为其新建结点,并赋其权值为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);
}
}
建立哈夫曼树。
I 在1)建立的链表中,挑选出未标记且权值最小的结点,将其移动至第一个结点位置,并且进行标记,并且重复次操作一次;
II 新建结点为这两个结点的父节点,并取代这两个结点在链表中的位置,其权值为两个子节点权值之和;
III 回到步骤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--;
}
}
②哈夫曼树应用
打印哈夫曼树。
I 输出根结点存储字符,若没有则不处理;如果此结点为叶结点,则结束;
II 如果有左子树,画出需要的线条与圆圈,进入左子树处理过程;
III 如果有右子树,画出需要的线条与圆圈,进入右子树处理过程;
类C描述:
voi
原创力文档


文档评论(0)