哈夫曼编码和译码c语言,哈夫曼编码译码C语言编写

满意答案

00e27ab806e4881f8254fe7ae8741834.png

kitwz775

2013.06.17

00e27ab806e4881f8254fe7ae8741834.png

采纳率:54%    等级:12

已帮助:8258人

#include

#include

#include

typedef char ElemType;

typedef struct{

ElemType elem;

unsigned int weight;

unsigned int parent,lchild,rchild;

}HTNode,*HuffmanTree;

typedef char** HuffmanCode;

typedef int Status;

typedef struct {

char elem;

unsigned int weight;

}Weight; // save the information of the symbolizes;

void HuffmanCoding(HuffmanTree *,HuffmanCode *,Weight *,int);

void Select(HuffmanTree,int,int *,int *);

void OutputHuffmanCode(HuffmanTree,HuffmanCode,int);

Status main(void)

{

HuffmanTree HT;

HuffmanCode HC;

Weight *w;

char c;

int i,n;

int wei;

printf("input the tatol number of the Huffman Tree:" );

scanf("%d",&n);

w=(Weight *)malloc(n*sizeof(Weight));

for(i=0;i

printf("input the element & its weight:");

scanf("%1s%d",&c,&wei);

w[i].elem=c;

w[i].weight=wei;

}

HuffmanCoding(&HT,&HC,w,n);

OutputHuffmanCode(HT,HC,n);

return 1;

}

00分享举报

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值