- 1、本文档共11页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
西安郵電學课程 目: 哈夫曼编码
院系名称: 计算机学院
专业名称: 软件工程
班 级: 1101班
学生姓名: 付添
学号(8位): 指导教师: 李培
设计起止时间:2012年月日~20年月日一. 设计目的
1.更好的理解哈夫曼树及其应用;
2.利用哈夫曼算法可以缩短指令字的长度,减少程序的总长度增加指令所能表示
的操作信息和地址信息;
3.通过对哈夫曼算法的设计使得我们对有关哈夫曼的知识更加了解,扩展了个人
的知识层面,加深了对算法学习的兴趣。
设计内容
主要包括哈夫曼树的创建,哈夫曼的编码过程,解码过程以及将编码和解码的信息最后存入到文件中的过程。
三.概要设计
1.功能模块图;
调用
\
2.各个模块详细的功能描述。
(1)creat(a);//哈夫曼树的创建
1.打开SouceFile.TXT源文件,定义变量w[]用来统计总的字符个数,定义标记量j来记录形同字符出现次数,最后w[]中的值为每个字符出现的次数,即权值。
2.在此函数中调用select()函数,用来寻找森林中权值最小的两个结点, select()函数得到的两个权值分别作为左右孩子,将他们的权值和作为其双亲结点的权值,利用for()循环,得到哈夫曼树。
(2)tthufmtree(a);//哈夫曼树的编码过程
将得到的哈夫曼树中的左孩子用0标记,右孩子用1标记;从叶子结点向上倒推,利用while循环为第i个编码分配空间,最后将编码复制到hc[i]中,释放空间。并将编码存入文件中,根据系统提示选择yes可看出平均码长。直观的表示了压缩。
(3)yima(a);//哈夫曼译码及其文件显示
从文件中读出要译码的信息根据哈夫曼树进行译码操作,并将解码后信息存入DeCodeFile.TXT文件中,并显示出来。
四.详细设计
1.功能函数的调用关系图
2.各功能函数的数据流程图
3.重点设计及编码
typedef struct
{
char data;
int weight;
int parent;
int lchild;
int rchild;
}htnode,hfmtree[M+1];
typedef char *hfmtcode[N+1];
//哈夫曼树的编码
void tthfmtcode(hfmtree ht,hfmtcode hc,int n)
{
FILE *pf;
char name[20];
int i,c,p,start;
char *cd;
cd=(char *)malloc((n+1)*sizeof(char));
cd[n-1]=\0;
for(i=1;i=n;i++)
{
start=n-1;
c=i;
p=ht[i].parent;
while(p!=0)
{
--start;
if(ht[p].lchild==c)
cd[start]=0;
else
cd[start]=1;
c=p;
p=ht[p].parent;
}
hc[i]=(char*)malloc((n-start)*sizeof(char));
strcpy(hc[i],cd[start]);
}
printf(输入要编码的文件名n);
scanf(%s,name);
if((pf=fopen(name,w))==NULL)
{
printf(文件打开失败\n);
return ;
}
for(i=1;i=n;i++)
{
printf(%c %s\n,ht[i].data,hc[i]);
fprintf(pf,%s,hc[i]);
}
printf(编码结果已存入%s\n,name);
free(cd);
fclose (pf);
printf(是否求出平均码长,输入yes继续,输入no跳出\n);
char s3[20];
float s4[N];
float sum=0.0,sum1=0.0;
scanf(%s,s3);
for(i=1;i=n;i++)
sum+=ht[i].weight;
for(i=0;i=n;i++)
s4[i]=ht[i].weight/sum*1.0;
if(strcmp(s3,yes)==0)
{
for(i=1;i=n;i++)
sum1+=s4[i]*strlen(hc[i]);
printf(该文
您可能关注的文档
- 第一讲:信息检索.ppt
- 第一讲JavaWeb概述.ppt
- 第一课《对象导论》.ppt
- 第一章 Java与面向对象方法.ppt
- 第一章 Java Web应用技术.ppt
- 第一章 Java技术入门.ppt
- 第一章 JDBC - 普遍系统架构与数据库解决方案.ppt
- 第一章 同步练习题及自测题答案.ppt
- 第一章JavaScript简介.ppt
- 第一章JavaScript入门.ppt
- 中国行业标准 DB/T 100-2024区域性地震安全性评价.pdf
- 《GM/T 0138-2024C-V2X车联网证书策略与认证业务声明框架》.pdf
- GM/T 0138-2024C-V2X车联网证书策略与认证业务声明框架.pdf
- DB/T 100-2024区域性地震安全性评价.pdf
- 中国行业标准 GM/T 0138-2024C-V2X车联网证书策略与认证业务声明框架.pdf
- 校园周边书店阅读氛围对初中生阅读素养提升的影响研究教学研究课题报告.docx
- 初中校园餐饮卫生监管与食品安全教育创新模式研究教学研究课题报告.docx
- 《文化遗产保护与旅游开发平衡机制的法律法规完善研究》教学研究课题报告.docx
- 《农作物病虫害生物防治技术的经济效益与社会影响分析》教学研究课题报告.docx
- 1 剖宫产术后子宫瘢痕憩室治疗中的并发症预防与护理措施教学研究课题报告.docx
文档评论(0)