- 1、本文档共25页,可阅读全部内容。
- 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,否则为其新建结点,并赋其权值为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
您可能关注的文档
- (员工考核表4.doc
- 《网页设计与制作实验大纲.doc
- 用电信多功能无线猫在加一个无线路由器.doc
- (员工考核评估.doc
- 《网页设计与制作教学计划表13计算机班10.doc
- (员工职称评定办法.doc
- (员工行为规范奖惩制度2.doc
- (员工职位管理制度.doc
- (员工行为规范奖惩制度.doc
- (员工转正考核表.doc
- 2023-2024学年广东省深圳市龙岗区高二(上)期末物理试卷(含答案).pdf
- 2023-2024学年贵州省贵阳市普通中学高一(下)期末物理试卷(含答案).pdf
- 21.《大自然的声音》课件(共45张PPT).pptx
- 2023年江西省吉安市吉安县小升初数学试卷(含答案).pdf
- 2024-2025学年广东省清远市九校联考高一(上)期中物理试卷(含答案).pdf
- 广东省珠海市六校联考2024-2025学年高二上学期11月期中考试语文试题.pdf
- 2024-2025学年语文六年级上册第4单元-单元素养测试(含答案).pdf
- 2024-2025学年重庆八中高三(上)月考物理试卷(10月份)(含答案).pdf
- 安徽省安庆市潜山市北片学校联考2024-2025学年七年级上学期期中生物学试题(含答案).pdf
- 贵州省部分校2024-2025学年九年级上学期期中联考数学试题(含答案).pdf
最近下载
- 2023年华东师范大学数据科学与大数据技术专业《操作系统》科目期末试卷A(有答案).docx VIP
- 2023年华东师范大学数据科学与大数据技术专业《操作系统》科目期末试卷B(有答案).docx VIP
- 2023年华东师范大学计算机科学与技术专业《操作系统》科目期末试卷A(有答案).docx VIP
- 人防通风系统安装施工方案管理文档.doc
- 标准图集 - 12J003 室外工程.pdf VIP
- 北师大版六年级数学上册3-3《天安门广场》教学设计.doc
- 东北财经大学通用PPT模板.pptx
- 屋盖钢结构设计讲课教案.pdf VIP
- 社会情感教育与教学质量改进.pptx
- 2024年华医网继续教育护理学基于循证理念的临床护理管理实践新进展题库及答案.docx VIP
文档评论(0)