c语言文件压缩与解压缩实验报告,哈弗曼树的文件压缩和解压实验报告(C语言).doc...

Lab05 树结构的应用

学号: 姓名: 实验时间:2011.5.24

1.问题描述

哈弗曼树的编码与译码

— 功能:实现对任何类型文件的压缩与解码

— 输入:源文件,压缩文件

— 输出:解码正确性判定,统计压缩率、编码与解码速度

— 要求: 使用边编码边统计符号概率的方法(自适应Huffman编码) 和事先统计概率的方法(静态Huffman编码) 。

2.1程序清单

程序书签:

main函数

压缩函数

select函数

encode函数

解压函数

#include

#include

#include

#include

#include

struct node{

long weight; //权值

unsigned char ch;//字符

int parent,lchild,rchild;

char code[256];//编码的位数最多为256位

int CodeLength;//编码长度

}hfmnode[512];

void compress();

void uncompress();

//主函数

void main()

{

int choice;

printf("请选择1~3:\n");

printf("1.压缩文件\n");

printf("2.解压文件\n");

printf("3.退出!\n");

scanf("%d",&choice);

if(choice==1)compress();

else if(choice==2)uncompress();

else if(choice==3)return;

else printf("输入错误!");

}

//压缩函数

void compress()

{

int i,j;

char infile[20],outfile[20];

FILE *ifp,*ofp;

unsigned char c;//

long FileLength,filelength=0;

int n,m;//叶子数和结点数

int s1,s2; //权值最小的两个结点的标号

char codes[256];

long sumlength=0;

float rate,speed;

int count=0;

clock_t start1, start2,finish1,finish2;

double duration1,duration2;

void encode(struct node *nodep,int n);//编码函数

int select(struct node *nodep,int pose);//用于建哈弗曼树中选择权值最小的结点的函数

printf("请输入要压缩的文件名:");

scanf("%s",infile);

ifp=fopen(infile,"rb");

if(ifp==NULL)

{

printf("文件名输入错误,文件不存在!\n");

return;

}

printf("请输入目标文件名:");

scanf("%s",outfile);

ofp=fopen(outfile,"wb");

if(ofp==NULL)

{

printf("文件名输入错误,文件不存在!\n");

return;

}

start1=clock() ;//开始计时1

//统计文件中字符的种类以及各类字符的个数

//先用字符的ASCII码值代替结点下标

FileLength=0;

while(!feof(ifp))

{

fread(&c,1,1,ifp);

hfmnode[c].weight++;

FileLength++;

}

FileLength--; //文件中最后一个字符的个数会多统计一次,所以要减一

hfmnode[c].weight--;

//再将ASCII转换为字符存入到结点的ch成员里,同时给双亲、孩子赋初值-1

n=0;

for(i=0;i<256;i++)

if(hfmnode[i].weight!=0)

{

hfmnode[i].ch=(unsigned

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
1. 进一步理解和掌握文件操作和命令行参数的实现; 2. 初步了解和掌握分析和使用第三方类库进行程序设计; 3. 初步接触如何对多种解决方案进行对比和选择 1. 分析给出的多文件打包/解包程序MyZip和单文件压缩程序Compress,将程序MyZip改写为一个能够处理多文件压缩/解压的控制台程序,可利用命令行参数控制其完成如下功能: 1. 将命令行参数指定的一组文件压缩为一个压缩文件。 其Usage为:MyZip /A <压缩文件名> <文件1> [<文件2> …] 2. 列出命令行参数指定的压缩文件中的各文件名。 其Usage为:MyZip /L <压缩文件名> 3将命令行参数指定的压缩文件解压到当前目录。 其Usage为:MyZip /E <压缩文件名> 提示:只需修改MyZip程序,将原先读取要加入的文件的内容后直接写到压缩文件中的代码,修改为先将要加入的文件压缩为一个临时文件后,再将压缩后的文件合并到原压缩文件中。压缩要加入的文件时,可调用LZARI类的Compress成员函数来实现。同样,解压缩时,可先将指定文件解包为各个(压缩后的)文件,再调用LZARI类的UnCompress成员函数,对解包出的临时文件进行解压缩,生成需要的(未压缩文件; 2. (选作)修改你的程序,将功能1)改为:如果指定的压缩文件不存在,则新建一个指定名称的压缩文件,包含指定的一组文件压缩内容;否则,将指定的一组文件压缩后加入到原有压缩文件中; 3. (选作)给出的多文件打包/解包程序MyZip所生成的打包文件中(以及由此改写而来的多文件压缩文件中),各文件的信息安排如下图所示。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值