资源简介
哈夫曼编码解码的实现及运行截图(C语言编写)
代码片段和文件信息
// HafuManCode.cpp : 定义控制台应用程序的入口点。
//
#include “stdafx.h“
#include
#include
#include
using namespace std;
#define n 5 //叶子数目
#define m (2*n-1) //结点总数
#define maxval 10000.0
#define maxsize 100 //哈夫曼编码的最大位数
typedef struct
{
char ch;
int weight;
int lchildrchildparent;
}hufmtree;
typedef struct
{
char bits[n]; //位串
int start; //编码在位串中的起始位置
char ch; //字符
}codetype;
void huffman(hufmtree tree[]);//建立哈夫曼树
void huffmancode(codetype code[]hufmtree tree[]);//根据哈夫曼树求出哈夫曼编码
void encode(codetype code[]char string[]);//电文编码
void decode(hufmtree tree[]);//依次读入电文,根据哈夫曼树译码
void main()
{
printf(“ ——哈夫曼编码——\n“);
printf(“总共有%d个字符\n“n);
hufmtree tree[m];
codetype code[n];
int ij;//循环变量
huffman(tree);//建立哈夫曼树
huffmancode(codetree);//根据哈夫曼树求出哈夫曼编码
printf(“【输出每个字符的哈夫曼编码】\n“);
for(i=0;i {
printf(“%c: “code[i].ch);
for(j=code[i].start;j printf(“%c “code[i].bits[j]);
printf(“\n“);
}
printf(“【读入原文,并进行编码】\n“);
char string[maxsize];
gets(string);
encode(codestring);
printf(“【读入电文,并进行译码】\n“);
decode(tree);//依次读入电文,根据哈夫曼树译码
getchar();
}
void huffman(hufmtree tree[])//建立哈夫曼树
{
int ijp1p2;//p1p2分别记住每次合并时权值最小和次小的两个根结点的下标
int small1small2f;
char c;
for(i=0;i {
tree[i].parent=0;
tree[i].lchild=-1;
tree[i].rchild=-1;
tree[i].weight=0;
}
printf(“【依次读入前%d个结点的字符及权值(中间用空格隔开)】\n“n);
for(i=0;i {
printf(“输入第%d个字符为和权值“i+1);
scanf(“%c %d“&c&f);
getchar();
tree[i].ch=c;
tree[i].weight=f;
}
for(i=n;i {
p1=0;p2=0;
small1=9999;small2=9999; //maxval是float类型的最大值
for(j=0;j if(tree[j].parent==0)
if(tree[j].weight {
small2=small1; //改变最小权、次小权及对应的位置
small1=tree[j].weight;
p2=p1;
p1=j;
}
else
if(tree[j].weight {
small2=tree[j].weight; //改变次小权及位置
p2=j;
}
tree[p1].parent=i;
tree[p2].parent=i;
tree[i].lchild=p1; //最小权根结点是新结点的左孩子
tree[i].rchild=p2; //次小权根结点是新结点的右孩子
tree[i].weight=tree[p1].weight+tree[p2].weight;
}
}//huffman
void huffmancode(codetype code[]hufmtree tree[])//根据哈夫曼树求出哈夫曼编码
//codetype code[]为求出的哈夫曼编码
//hufmtree tree[]为已知的哈夫曼树
{
int icp;
codetype cd; //缓冲变量
for(i=0;i {
cd.start=n;
cd.ch=tree[i].ch;
c=i; //从叶结点出发向上回溯
p=tree[i].parent; //tree[p]是tree[i]的双亲
while(p!=0)
{
cd.start--;
if(tree[p].lchild==c)
cd.bits[cd.start]=‘0‘; //tree[i]是左子树,生成代码‘0‘
else
cd.bits[cd.start]=‘1‘; //tree[i]是右子树,生成代码‘1‘
c=p;
p=tree[p].parent;
}
code[i]=cd; //第i+1个字符的编码存入code[i]
}
}//huffmancode
void encode(codetype code[]char string[])
{
printf(“【输出编码结果】\n“);
int length=strlen(string);
for(int k=0;k {
f
属性 大小 日期 时间 名称
----------- --------- ---------- ----- ----
文件 4286 2015-11-01 16:39 HafuManCode.cpp
文件 43740 2015-11-01 16:38 运行结果.png
----------- --------- ---------- ----- ----
48026 2
- 上一篇:NetCDF C++接口使用说明
- 下一篇:vigenere算法C语言实现
相关资源
- 哈夫曼编码译码器绝对可以运行c语言
- 哈夫曼树设计——利用哈夫曼编码进
- 数据结构C语言之哈夫曼编码
- 自适应哈夫曼编码C++
- 哈夫曼编码与解码(C语言实现)
- 用哈夫曼编码实现文件压缩代码+报告
- 哈夫曼编码译码器 C语言 数据结构课
- 哈夫曼编码与译码附报告
- 哈夫曼编码系统C语言实现
- 数据结构哈夫曼编码译码C语言版程序
- C语言-哈夫曼编码实验报告
- 基于哈夫曼编码的文件压缩解压程序
- 哈夫曼编码译码器实验报告内
- 哈夫曼编码
- c++实现的哈夫曼编码和解码源代码
- C++哈夫曼编码与译码课程设计实现源
- C++实现哈夫曼树及哈夫曼编码.rar
- n元哈夫曼编码
- 基于哈夫曼编码的文本文件压缩与解
- 基于C++和MFC的哈夫曼编码压缩软件的
- 数据结构实验-哈夫曼编码C语言实现实
- 哈夫曼编码 (C++实现)
- 哈夫曼编码(c++实现)
- 香农编码 哈夫曼编码 信息论期中作业
- 哈夫曼编码器c代码
- MFC下的哈夫曼编码及应用
- C语言编码哈夫曼树
- Huffman文件压缩解压缩-C语言-数据结构
- 哈夫曼编码(C语言版)
- 哈夫曼编码C语言的实现
评论
共有 条评论