- 1、本文档共9页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
数据结构实验报告
《数据结构》上机报告实验名称 Huffman 编码专业: 电子信息工程 班级: 电信1202学号: u201213415 姓名: 唐雷 指导教师: 蒋洪波 完成日期:2013-12-01一,需求分析现代社会是讲求效率的社会,什么都要求速度,在不出错的情况下,做任何事情都讲究越快越好。在计算机和互联网技术中,文本压缩就是一个非常重要的技术。玩儿电脑的人几乎都会应用压缩和解压软件来处理文件。因为它除了可以减少文档在磁盘上的空间外,还有重要的一点,就是我们可以在网络上以压缩的形式传输大量数据,使得保存和传递都更加高效。那么压缩而不出错是如何做到的呢?简单说,就是把我们要压缩的文本进行重新编码,以减少不必要的空间。尽管现在最新技术在编码上已经很好很强大,但这一切都来源于曾经的技术积累,而霍夫曼编码就是一种最基本的压缩编码的方法。基于此,本文将通过以奥巴马在上海的一次演讲的演讲词作为编码对象,编程实现对此的Huffman编码。二,概要设计原理:带权路径长度WPL最小的二叉树称作霍夫曼树。构造方法:用二叉树作为主要的数据结构。用带有weight, parent, lchild , rchild四个域的二叉链表来实现。具体过程:1,统计:扫描奥巴马的演讲稿,统计26个字母出现的次数,以之为该字母的权值。2,建树:用一数组依次储存对象的权值。每次从中选出最小的两个对象作为左右孩子与一新节点相连,此节点权值等于左右孩子权值之和。在数组中删除选出的节点,并把新节点考入数组中。在从此时的数组中选出权值最小的两个节点作为左右孩子,与另一新节点相连,新节点为左右孩子权值之和。重复上述操作,直至数组中所有元素用完,此时建树完毕。这棵树就是Huffman树。3,编码:规定根节点到左子树路径的编码为1,到右子树路径的编码为0.从根节点出发到每一个节点的路径就是Huffman编码。模块划分:void tongji(char *str,int *w); //str指针指向奥巴马的演讲稿的第一个字符,w数组用来保存26个字母出现的次数,即权值。通过此函数可以把演讲稿遍历一边,把权值的信息反馈给其它模块进行处理。void HuffmanCoding( int *w,int n)//w记录了26个字母分别的权值。,n待编码的字母的个数,即26。通过此函数可以完成建树和编码的过程,并把编码结果打印出来。void Select(HuffmanTree HT,int n,int s1,int s2)//每次从储存对象和权值的数组中找到最小两个的位置,并把此位置的信息返回给 HuffmanCoding以建树。三,代码实现#includestdio.h#includestdlib.h#includestring.htypedef struct{unsigned int weight;unsigned int parent,lchild,rchild;}HTNode,*HuffmanTree; //定义了二叉链表,节点和树的信息。typedef char **HuffmanCode; //定义了一个二重指针用了指向每个字母的编码。void main(){void tongji(char *str,int *w); void HuffmanCoding(int *w,int n);char ch,str[8000];int i=0;int w[26]={0};FILE *fp;if((fp=fopen(a.txt,r))==NULL){printf(cannot open!\n);exit(0);} printf(读入演讲稿如下:\n);while(!feof(fp)) { //遍历整个演讲稿,并把演讲稿的信息储存咋str[]数组中。ch=fgetc(fp);str[i++]=ch; }str[i]=\0;strlwr(str); //把所有字母都编程小写,以便与统计。printf(%s,str); //打印读出的奥巴马演讲的信息。tongji(str,w); //统计26个字母出现的次数。 HuffmanCoding(w,26); //进行建树及编码。}void tongji(char *str,int *w){char a[]=abcdefghijklmnopqrstuvwxyz;int sum[26]={0};int i,j,t,n;i=0; printf(\n统计字符数目如下:\n);for(i=0;str[i]!=#;i++){sum[str[i]-a]++;}for(i=0;i26;i++){if(sum[i]0) { printf(%c\t%d\n,a[i],sum[i]); w[i]=sum[i];}}}void HuffmanCoding( int *w
您可能关注的文档
最近下载
- EXC9000励磁系统简介.ppt VIP
- 状语从句时间状语从句.pptx VIP
- 2024山东城市建设职业学院招聘笔试真题及参考答案详解.docx VIP
- 13685光与色彩自考课程.docx VIP
- 2024年山东城市建设职业学院招聘笔试真题附答案详解.docx VIP
- 重症自身免疫性脑炎监测与治疗中国专家共识(2024版).pptx
- 2024山东城市建设职业学院招聘笔试真题附答案详解.docx VIP
- 商用车推力杆多自由度动态载荷耐久试验方法201106.pdf VIP
- “体文旅”融合发展:概念重构、内涵解析与演进历程.docx VIP
- 《检验检测机构资质认定评审准则》试题及标准答案.docx VIP
文档评论(0)