压缩图片实验实验报告书示例pdf.docx

  1. 1、本文档共10页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
压缩图片实验实验报告书示例pdf

学生学号实验课成绩 学 生 实 验 报 告 书 实验课程名称 数据结构与算法综合实验 开课学院 计算机科学与技术学院 指导教师姓名 伍新华 学生姓名 学生专业班级 2015 -- 2016 学年 第 2 学期 1 实验课程名称:数据结构与算法综合实验实验项目名称二叉树与赫夫曼图片压缩报告成绩实验者专业班级组别同组者完成日期年 月 日 第一部分:实验分析与设计(可加页) 一、 实验目的和要求 1.目的 掌握树的存储结构 掌握二叉树的三种遍历方法 掌握 Huffman 树、Huffman 编码等知识和应用 使用 C++、文件操作和 Huffman 算法实现“图片压缩程序”专题编程。 2.要求 针对一幅 BMP 格式的图片文件,统计 256 种不同字节的重复次数,以每种字 节重复次数作为权值,构造一颗有 256 个叶子节点的哈夫曼二叉树。 利用上述哈夫曼树产生的哈夫曼编码对图片文件进行压缩。 压缩后的文件与原图片文件同名,加上后缀.huf(保留原后缀),如 pic.bmp 压缩后 pic.bmp.huf 二、 分析与设计 依据上述的实验目的与要求,可导出实现的二叉树与赫夫曼图片压缩软件的流 程为: 读取图片文件、统计权值 生成 Huffman 树 ③ 生成 Huffman 编码 ④ 压缩图片文件 ⑤ 保存压缩的图片文件 1.数据结构的设计 记录统计 256 种不同字节的重复次数使用整型数组。 Unsigned int weight[256]; 二叉树的存储结构。使用结构体存储节点,使用数组存储树的节点,使用静态 二叉链表方式存储二叉树。 Struct HTNode{ Unsigned int weight; Int parent; Int lchild; Int rchild; }; Typedef HTNode *HuffmanTree; 1 Huffman 编码存储结构 定义一二维数组:char HufCode[256][];因考虑每个字节的 Huffman 编??长度 不一样,可使用字符串指针数组: Char *HuffmanCode[256]; 压缩文件的算法的数据结构 为正确解压文件,除了要保存原文件长度外,还要保存原文件中 256 种字节重 复的次数,即权值。定义一个文件头,保存相关的信息: Struct fHEAD { Char type[4]; //文件类型 Unsigned int length; //原文件的长度 Unsigned char weight[256]; //权值 } 压缩文件时,定义一个内存缓冲区: Unsigned char *pBuffer; //其大小视原文件压缩后的大小 2.核心算法设计 1)生成 Huffman 树算法Input: Unsigned intweight[256];//权值Output: HuffmanTree pHT[512];//哈夫曼树,静态二叉链表Int root;//树的根节点指针Process: int CreateHuffmanTree(HuffmanTree pHT[], Unsigned int weight[]){ pHT = ( HuffmanTree ) malloc ( (512 ) * sizeof ( HTNode ) ); for ( p = pHT+1, i = 1; i 256; ++i, ++p) *p = { weight[i-1], 0, 0, 0 }; for ( ; i = 511; ++i, ++p ) *p = { 0, 0, 0, 0 }; for ( i = 256; i = 511; ++i ) { //构造 n-1 个分支结点 Select ( pHT, i-1, s1, s2 ); //pHT[1..i-1]中 parent 为 0 的 w 最小的 2 个结点 HT [s1].parent = i; HT [s2].parent = i; HT [i].lchild = s1; HT [i].rchild = s2; HT [i].weight = HT [s1].weight + HT [s2].weight; } Return 511; } 2)生成 Huffman 编码算法 Input: HuffmanTree pHT[512];n; //n 为叶子节点数 Output: Char *HuffmanCode[256]; Process: int HuffmanCoding(HuffmanCode pHC,Huf

文档评论(0)

haihang2017 + 关注
实名认证
内容提供者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档