哈夫曼树 实验报告.pdfVIP

  • 22
  • 0
  • 约5.48千字
  • 约 5页
  • 2020-08-15 发布于广东
  • 举报
计算机科学与技术学院 数据结构 实验报告 班级 2014 级计算机1 班 学号 20144138021 姓名 张建华 成绩 实验项目 简单哈夫曼编/译码的设计与实现 实验日期 2016.1.5 一、实验目的 本实验的目的是进一步理解哈夫曼树的逻辑结构和存储结构,进一步提高使用理论知识指导解决实际问 题的能力。 二、实验问题描述 利用哈夫曼编码进行通信可以大大提高信道利用率,缩短信息传输时间,降低传输成本。但是,这要 求在发送端通过一个编码系统对待传数据预先编码,在接收端将传来的数据进行译码,此实验即设计这样的 一个简单编/码系统。系统应该具有如下的几个功能: 1、接收原始数据。 从终端读入字符集大小 n,以及 n 个字符和 n 个权值,建立哈夫曼树,并将它存于文件 hfmtree.dat 中。 2、编码。 利用已建好的哈夫曼树(如不在内存,则从文件hfmtree.dat 中读入),对文件中的正文进行编码, 然后将结果存入文件codefile.dat 中。 3、译码。 利用已建好的哈夫曼树将文件 codefile.dat 中的代码进行译码,结果存入文件 textfile.dat 中。 4、打印编码规则。 即字符与编码的一一对应关系。 5、打印哈夫曼树, 将已在内存中的哈夫曼树以直观的方式显示在终端上。 三、实验步骤 1、实验问题分析 1、构造哈夫曼树时使用静态链表作为哈夫曼树的存储。 在构造哈夫曼树时,设计一个结构体数组HuffNode 保存哈夫曼树中各结点的信息,根据二 叉树的性质可知,具有n 个叶子结点的哈夫曼树共有2n-1 个结点,所以数组HuffNode 的大小设置为2n-1, 描述结点的数据类型为: Typedef strcut { Int weight;/*结点权值*/ Int parent; Int lchild; Int rchild; }HNodeType; 2、求哈夫曼编码时使用一维结构数组HuffCode 作为哈夫曼编码信息的存储。 求哈夫曼编码,实质上就是在已建立的哈夫曼树中,从叶子结点开始,沿结点的双亲链域回 退到根结点,没回退一步,就走过了哈夫曼树的一个分支,从而得到一位哈夫曼码值,由于一个字符的哈夫 曼编码是从根结点到相应叶子结点所经过的路径上各分支所组成的0、1 序列,因此先得到的分支代码为所求 编码的低位码,后得到的分支代码位所求编码的高位码,所以设计如下数据类型: #define MAXBIT 10 Typedef struct { Int bit[MAXBIT]; Int start; 1 共 页 第 页 }HCodeType; 3、文件hfmtree.dat、codefile.dat 和textfile.dat。 2、功能(函数)设计 (1)、初始化功能模块。 此功能模块的功能为从键盘接收字符集大小n,以及n 个字符和n 个权值。 (2 )、建立哈夫曼树的功能模块。 此模块功能为使用 1 中得到的数据按照教材中的构造哈夫曼树的算法构造哈夫曼树,即将 HuffNode 数组中的各个位置的各个域都添上相关的值,并将这个结构体数组存于文件hfmtree.dat 中。 (3 )、建立哈夫曼编码的功能模块。 此模块功能为从文件 hfmtree.dat 中读入相关的字符信息进行哈夫曼编码,然后将结果存入 codefile.dat 中,同时将字符与0、1 代码串的一一对应关系打印到屏幕上。 (4)、译码的功能模块。 此模块功能为接收需要译码的0、1 代码串,按照3 中建立的编码规则将其翻译成字符集中字符 所组成的字符串形式,存入文件textfile.dat,同时将翻译的结果在屏

文档评论(0)

1亿VIP精品文档

相关文档