打印
[技术支持]

用哈夫曼树编码并译码,为啥没有输出呢?

[复制链接]
1263|7
手机看帖
扫描二维码
随时随地手机跟帖
跳转到指定楼层
楼主
本帖最后由 芯圣电子官方QQ 于 2023-7-20 10:37 编辑
#include<stdio.h>
#include<stdlib.h>
#include<string.h>
typedef struct
{
char data;
int weight;
int parent,lchild,rchild;
}HTNode,*HuffmanTree;

typedef char **HuffmanCode;

void Select(HuffmanTree &HT,int m,int &s1,int &s2)//选择两个权值较小的结点,并返回序号
{
int i,j,min1,min2;
min1=min2=1000;
for(i=1;i<=m;i++)
if(HT[i].parent==0&&HT[i].weight<min1)
{
min1=HT[i].weight;
s1=i;
}
for(j=1;j<=m&&j!=s1;j++)
if(HT[i].parent==0&&HT[i].weight<min2)
{
min2=HT[j].weight;
s2=j;
}
}

void CreateHuffmanTree(HuffmanTree &HT,int n)//建立哈夫曼树
{
if(n<=1) return;
HT=(HuffmanTree)malloc(sizeof(HTNode)2n);
int i,j,s1,s2;
char ch='a';
for(i=1;i<=(2n-1);++i)
{
HT[i].parent=0;
HT[i].lchild=0;
HT[i].rchild=0;
}
for(j=1;j<=n;++j,ch++)
{
if(j==1)
{
HT[1].data=' ';
scanf("%d",&HT[j].weight);
}
else
{
HT[j].data=ch;
scanf("%d",&HT[j].weight);
}
}
for(i=n+1;i<=(2n-1);++i)
{
Select(HT,i-1,s1,s2);
HT[s1].parent=i;
HT[s2].parent=i;
HT[i].weight=HT[s1].weight+HT[s2].weight;
HT[i].lchild=s1;
HT[i].rchild=s2;
}
}

void CreateHuffmanCode(HuffmanTree HT,HuffmanCode &HC,int n)//求哈夫曼编码
{
HC=new char*[n+1];
char *cd;
cd=(char *)malloc(sizeof(char)*n);
int i,start,c,f;
for(i=1;i<=n;++i)
{
start=n-1;
c=i;
f=HT[i].parent;
while(f!=0)
{
--start;
if(HT[f].lchild==c) cd[start]='0';//回溯时走左分支为0,右分支为1
else cd[start]='1';
c=f;
f=HT[f].parent;
}
HC[i]=(char)malloc(sizeof(char)(n-start));
strcpy(HC[i],&cd[start]);
}
delete(cd);
}

void InterpretCode(HuffmanCode HC,char *str)//译码
{
int i;
for(i=0;i<strlen(str);i++)
{
if(str[i]==' ') printf("%s",HC[1]);
else{
if(str[i]>='A'&&str[i]<='Z') str[i]=str[i]+32;
if(str[i]>='a'&&str[i]<='z') printf("%s",HC[str[i]-95]);
}
}
}

int main()
{
HuffmanTree HT;
HuffmanCode HC;
CreateHuffmanTree(HT,27);
printf("请输入报文:");
CreateHuffmanCode(HT,HC,27);
char s[100];
gets(s);
InterpretCode(HC,s);
return 0;
}


使用特权

评论回复
沙发
tpgf| | 2022-7-5 13:39 | 只看该作者
这是一个算法吗

使用特权

评论回复
板凳
晓伍| | 2022-7-5 13:48 | 只看该作者
这种编码方式用在什么产品上啊

使用特权

评论回复
地板
八层楼| | 2022-7-5 14:11 | 只看该作者
这种主要就是用于编码解码吗

使用特权

评论回复
5
观海| | 2022-7-5 14:20 | 只看该作者
看代码好像并不复杂啊

使用特权

评论回复
6
guanjiaer| | 2022-7-5 14:29 | 只看该作者
理论上应该有什么输出呢

使用特权

评论回复
7
heimaojingzhang| | 2022-7-5 14:40 | 只看该作者
会输出一些编码吗?

使用特权

评论回复
8
chenqianqian| | 2022-7-6 08:29 | 只看该作者
算法实现对吗?

使用特权

评论回复
发新帖 我要提问
您需要登录后才可以回帖 登录 | 注册

本版积分规则

12

主题

88

帖子

0

粉丝