- 1、本文档共6页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
#includestdio.h
#includestdlib.h
#includemath.h
#includestring.h
#defineN1000
charkind[N]={\0};
intnum[N]={0};
intcount=0;
ints1,s2;
typedefstruct
{
intweight;/*字符权重*/
intparent,lchild,rchild;
}HTNode,*HuffmanTree;/*定义哈夫曼树结点*/
typedefchar**HuffmanCode;
structcharcode
{
chardata;
charcode[20];
}Code[N],d[N],e[N];
voidCreat_message( )/*输入字符并存入文件*/
{
FILE*fp;
charc;
if((fp=fopen(文本文件.txt,wb))==NULL)
{
printf(cannotopenthisfile!\n);
return;
}
printf(请输入原代码,以#表示结束\n);
do{
scanf(%c,c);
fputc(c,fp);
}while(c!=#);
fclose(fp);
}
voidCalculate( )/*计算文件中字符的权值*/
{
charc;
inti=1,k;
FILE*fp;
if((fp=fopen(文本文件.txt,rb))==NULL){
printf(cannotopenthisfile\n);
return;
}
c=fgetc(fp);
while(c!=#){
for(k=0;ki;k++)
if(c==kind[k]){
num[k]++;break;}
if(k=ikind[k-1]!=c){
kind[i]=c;num[i]++;i++;
}
c=fgetc(fp);
}
count=i-1;
}
voidselect(HuffmanTreeHu,intj)/*找寻输入的字符数据中权值最小的两个结点*/
{
intk=1,t;
while(Hu[k].parent!=0)k++;
for(t=k;t=j;t++)
if(Hu[t].parent==0Hu[t].weightHu[k].weight)
k=t;
s1=k;
k=1;
while(Hu[k].parent!=0||k==s1)k++;
for(t=k;t=j;t++)
if(Hu[t].weightHu[k].weightHu[t].parent==0t!=s1)
k=t;
s2=k;
}
voidHuffmanCoding( )/*建立哈夫曼树并编码*/
{
voidselect(HuffmanTreeHu,intj);
HuffmanTreeHT;
HuffmanCodeHC;
intm,i,start,f,c;
char*cd;
FILE*fp;
if(count=1)return;
m=2*count-1;
HT=(HuffmanTree)malloc((m+1)*sizeof(HTNode));
for(i=1;i=count;i++)
HT[i].weight=num[i];
for(i=1;i=m;i++){
HT[i].parent=0;
HT[i].lchild=0;
HT[i].rchild=0;}
for(i=count+1;i=m;i++){
select(HT,i-1);
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;}
HC=(HuffmanCode)malloc((count+1)*sizeof(char*));
cd=(char*)malloc(count*sizeof(char));
cd[count-1]=\0;
for(i=1;i=count;i++){
start=count-1;
for(c=i,f=HT[i].parent;f!=0;c=f,f=HT[f].parent)
if(HT[f].lchild==c)cd[--start]=0;
elsecd[--start]=1;
HC[i]=(char*)malloc((count-start)*sizeof(char));
strcpy(HC[i],cd[start]);}
if((fp=fopen(字符代码.txt,wb))==NULL)
{
printf(cannotopenthisfile\n);
return;
}
for(i=1;i=count;i++){
Code[i].data=kind[i];
s
文档评论(0)