2022年数据结构哈夫曼编码实验报告 .pdf
《2022年数据结构哈夫曼编码实验报告 .pdf》由会员分享,可在线阅读,更多相关《2022年数据结构哈夫曼编码实验报告 .pdf(6页珍藏版)》请在淘文阁 - 分享文档赚钱的网站上搜索。
1、北京邮电大学信息与通信工程学院第 1 页数据结构实验报告实验名称:实验 3树(哈夫曼编 /解码器)学生姓名:班级:班内序号:学号:日期: 2011年 12 月 5 日1实验要求利用二叉树结构实现哈夫曼编/ 解码器。基本要求:1、 初始化 (Init ) :能够对输入的任意长度的字符串s 进行统计,统计每个字符的频度,并建立哈夫曼树2、 建立编码表 ( CreateTable) : 利用已经建好的哈夫曼树进行编码,并将每个字符的编码输出。3、 编码 ( Encoding) :根据编码表对输入的字符串进行编码,并将编码后的字符串输出。4、 译码 ( Decoding) :利用已经建好的哈夫曼树对编
2、码后的字符串进行译码,并输出译码结果。5、 打印 (Print):以直观的方式打印哈夫曼树(选作)计算输入的字符串编码前和编码后的长度,并进行分析,讨论哈夫曼编码的压缩效果。并用 I love data Structure, I love Computer 。I will try my best to study data Structure. 进行测试。2. 程序分析哈夫曼树结点的存储结构包括双亲域parent,左子树lchild ,右子树rchild ,还有字符word ,权重 weight ,编码 code对用户输入的信息进行统计,将每个字符作为哈夫曼树的叶子结点。统计每个字符出现的次数
3、作为叶子的权重,统计次数可以根据每个字符不同的ASCII 码,根据叶子结点的权重建立一个哈夫曼树。建立每个叶子的编码从根结点开始,规定通往左子树路径记为0,通往右子树路径记为1。由于编码要求从根结点开始,所以需要前序遍历哈夫曼树,故编码过程是以前序遍历二叉树为基础的。同时注意递归函数中能否直接对结点的编码域进行操作。编码信息只要遍历字符串中每个字符,从哈夫曼树中找到相应的叶子结点,取得相应的编码。最后再将所有找到的编码连接起来即可。译码则是将编码串从左到右逐位判别,直到确定一个字符。这就是哈夫曼树的逆过程。精选学习资料 - - - - - - - - - 名师归纳总结 - - - - - -
4、-第 1 页,共 6 页北京邮电大学信息与通信工程学院第 2 页遍历编码串, 从哈夫曼树中找到相应的叶子结点,取得相应的字符再将找到的字符连接起来即可。2.1 存储结构哈夫曼树结点存储结构2.2 关键算法分析1. 统计字符频度自然语言描述:(1)取出字符串中的一个字符(2)遍历所有初始化的哈夫曼树结点(3)如果结点中有记录代表的字符且字符等于取出的字符,说明该字符的叶子存在,则将该结点的权值加1 (4)如果所有结点记录的字符均没有与取出的字符一致,说明该字符的叶子不存在,则将结点的字符记为取出字符,并将权重设为1 (5)重复以上步骤,直至字符串中所有字符全部遍历伪代码描述:1. for(int
5、 i=0;ilength;i+) 1.1 for (int j=0;jlength;j+) 1.1.1if (WordStri=HuffTreej.word)/若字符已被统计,则增加权值即可1.1.1.1 权重 +; 1.1.1.2 break; 1.1.2 else if(!HuffTreej.word)/否则需要一个新结点储存这个字符1.1.2.1 HuffTreej.word=WordStri; 1.1.2.2 HuffTreej.weight=1;1.1.2.3 叶子结点个数 +; 1.1.2.4 break; 时间复杂度O(n2),空间复杂度S(0)2. 构造哈夫曼树自然语言描述:(
6、1)选出权值最小的两个结点,其权值和作为其根结点的权值,最小的结点作为左子树,次小的作为右子树,不断将两棵子树合并为一棵树。(2)重复上述过程,直至所有结点全被遍历完伪代码描述:1. int leaves=n; parent lchild rchild word weight code 精选学习资料 - - - - - - - - - 名师归纳总结 - - - - - - -第 2 页,共 6 页北京邮电大学信息与通信工程学院第 3 页2.for (int j=n;j2*n-1;j+) 2.1 int j1=0;int j2=0; 2.2 Select(HuffTree,leaves,j,j1
7、,j2);/ 选出两个权值最小结点2.3 HuffTreej1.parent=j;HuffTreej2.parent=j; 2.4 HuffTreej.weight=HuffTreej1.weight+HuffTreej2.weight;/根结点权值等于两个结点权值和2.5 HuffTreej.lchild=j1;HuffTreej.rchild=j2;/左子树为权值最小,右子树权值次小2.6 叶子数 -;时间复杂度O(n),空间复杂度S(2)3. 为每个叶子结点编码自然语言描述:(1)初始化一个字符数组Code 暂存每个叶子结点的编码。(2)前序遍历哈夫曼树(3)若结点左右子树都为-1,则将
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 2022年数据结构哈夫曼编码实验报告 2022 数据结构 哈夫曼 编码 实验 报告
限制150内