2023年新版哈夫曼树实验报告.docx
《2023年新版哈夫曼树实验报告.docx》由会员分享,可在线阅读,更多相关《2023年新版哈夫曼树实验报告.docx(8页珍藏版)》请在淘文阁 - 分享文档赚钱的网站上搜索。
1、计算机科学与技术学院数据结构实验报告班级 2 02 3级计算机1班 学号姓名 张建华 成绩实验项目简朴哈夫曼编/译码的设计与实现 实验日期一、实验目的本实验的目的是进一步理解哈夫曼树的逻辑结构和存储结构,进一步提高使用理论知识指导解决实际问 题的能力。二、实验问题描述运用哈夫曼编码进行通信可以大大提高信道运用率,缩短信息传输时间,减少传输成本。但是,这规定 在发送端通过一个编码系统对待传数据预先编码,在接受端将传来的数据进行译码,此实验即设计这样的一个 简朴编/码系统。系统应当具有如下的几个功能:1、接受原始数据。从终端读入字符集大小n ,以及n个字符和n个权值,建立哈夫曼树,并将它存于文献
2、hfmtree. da t 中。2、编码。,运用已建好的哈夫曼树(如不在内存,则从文献h fmtree. dat中读入),对文献中的正文进行编码, 然后将结果存入文献codefile, dat中。3、译码。运用已建好的哈夫曼树将文献co defile, dat中的代码进行译码,结果存入文献text file, dat 中。4、打印编码规则。即字符与编码的一一相应关系。5、打印哈夫曼树,。将已在内存中的哈夫曼树以直观的方式显示在终端上。三、实验环节1、实验问题分析1、构造哈夫曼树时使用静态链表作为哈夫曼树的存储。在构造哈夫曼树时,设计一个结构体数组Huff No de保存哈夫曼树中各结点的信息,
3、根据二叉树的性质可知,具有n个叶子结点的哈夫曼树共有2n-1个结点,所以数组Hu f f Nod e的大小设立为 2n-1,描述结点的数据类型为:Typede f str c ut(I nt w e i ght ; /* 结点权值* /Int parent;I nt Ichi Id;I nt r c h i I d;)HNod e T ype;2、求哈夫曼编码时使用一维结构数组Huf f Cod e作为哈夫曼编码信息的存储。,求哈夫曼编码,实质上就是在已建立的哈夫曼树中,从叶子结点开始,沿结点的双亲链域回退到根结点,没回退一步,就走过了哈夫曼树的一个分支,从而得到一位哈夫曼码值,由于一个字符的
4、哈 夫曼编码是从根结点到相应叶子结点所通过的途径上各分支所组成的0、1序列,因此先得到的分支代码为所 求编码的低位码,后得到的分支代码位所求编码的高位码,所以设计如下数据类型:#def ine MAXB IT 10Typed e f struct(。 Int bitMAXBIT;Int sta r t; HCodeT ype;3、文献 hfmtre e . datv codef i Ie. dat 和 textfi I e . dato2、功能(函数)设计(1)、初始化功能模块。此功能模块的功能为从键盘接受字符集大小n,以及n个字符和n个权值。(2 )、建立哈夫曼树的功能模块。此模块功能为使用
5、1中得到的数据按照教材中的构造哈夫曼树的算法构造哈夫曼树,即将HuffN ode数组中的各个位置的各个域都添上相关的值,并将这个结构体数组存于文献h f mtr e e.dat中。(3)、建立哈夫曼编码的功能模块。此模块功能为从文献hfmtree.dat中读入相关的字符信息进行哈夫曼编码,然后将结果存入cod efile.dat中,同时将字符与0、1代码串的一一相应关系打印到屏幕上。(4)、译码的功能模块。此模块功能为接受需要译码的0、1代码串,按照3中建立的编码规则将其翻译成字符集中字符所组成的字符串形式,存入文献t extfi 1 e.da t,同时将翻译的结果在屏幕上打印输出。(5)、打
6、印哈夫曼树的功能模块。此模块功能为从HuffNode数组中读入相关的结点信息,以图形的方式将各个结点以及叶子结 点的权值和左分支上的0和右分支上的1画出来。四、实验结果(程序)及分析1、实验重要代码t y pedef structt y pedef struct/*结点结构体*/string h fmstr;string h fmstr;/*结点内容*/ i nt weight;/ *结点权值*/i nt parent;int I chi Id;HNodeTy pe;ty p e d ef s t r u ctty p e d ef s t r u ct/*编码结构体*/i nt bit MA
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 2023 新版 哈夫曼树 实验 报告
限制150内