首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

哈夫曼实现文件压缩压缩c语言

写一个对文件进行压缩和解压缩的程序,功能如下: ① 可以对纯英文文档实现压缩和解压; ② 较好的界面程序运行的说明。...文件压缩与解压 姓名: 范天祚 1 程序说明 1.1数据结构 哈夫曼树 1.2函数功能说明 printfPercent界面 compress()读取文件内容并加以压缩,将压缩内容写入另一个文档 uncompress...()解压缩文件,并将解压后的内容写入新文件 1.3 程序编写的思路及流程 压缩:统计字符出现次数、将节点按出现次数排序、构造哈夫曼树、设置字符编码、读文件字符、按设置好的编码替换字符、写入存储文件 解压...//关闭文件 printf("压缩文件为:%s\n",outputfile); printf("压缩文件有:%d字符\n",pt1 + 4); return 1;...//返回压缩成功信息 } //函数:uncompress() //作用:解压缩文件,并将解压后的内容写入新文件 int uncompress(const char *filename,const char

2.3K20
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    C语言实现哈夫曼编码_哈夫曼编码压缩文件c语言

    用一个有序链表(从大到小)来保存节点,然后通过链表来构造霍夫曼树, 再由霍夫曼树得到霍夫曼编码**/ typedef struct huffman_tree_node{ int weight;//权重 char c;...HuffmanTreeNode; //霍夫曼树节点 typedef struct huffman_code{ char *s;//编码 如 010, 00, .... int len;//编码长度 char c;...* createHuffmanTreeNode(char c, int weight){ HuffmanTreeNode * node = (HuffmanTreeNode *)calloc(1, sizeof...(HuffmanTreeNode)); node->c = c; node->weight = weight; node->nextHuffmanTreeNode = NULL; node->leftHuffmanTreeNode...= 0){ //到叶子节点了 //打印编码结果(或保存到结构体中): printf("%c->%s\n", node->c, s); free(s); return; } //遍历左节点 编码增加一个0

    99640

    C语言文件操作_C语言调用文件

    文章目录 文件打开与关闭 文件读写操作 读/写文件中的字符串 格式化读写文件操作 文件定位函数 作业使用案例(自己可以全部完成一遍): 文件打开与关闭 C文件操作用库函数实现,包含在stdio.h中。...文件使用方式: 打开文件文件读/写→关闭文件 系统自动打开和关闭三个标准文件: 标准输入——键盘 stdin 标准输出——显示器 stdout 标准出错输出—–显示器 stderr...文件读写操作 当我们把文件打开之后,就可以对它进行读与写的操作。...C语言规定的起始位置有三种,分别为文件开头、当前位置和文件末尾,每个位置都用对应的常量来表示: 例如:把位置指针移动到离文件开头100个字节处: fseek(fp, 100, 0);...代码如下: #include #include #include #include int main() {

    9.4K10

    C 语言文件操作 ( 配置文件读写 | 完整代码示例 ) ★

    文章目录 一、头文件 cfg.h 二、核心业务 cfg.c 三、主函数 四、执行结果 一、头文件 cfg.h ---- // 防止多次导入 #ifndef __CFG_H__ #define __CFG_H...__ // 兼容 C++ #ifdef __cplusplus extern "C" { #endif // __cplusplus // 定义接口时 , 如果函数形参用作输入数据时 , 可以在形参名很后面添加...int value_len /*in*/); #ifdef __cplusplus } #endif // __cplusplus #endif // __CFG_H__ 二、核心业务 cfg.c...char line_buffer[MAX_LINE]; // 以只读的方式打开文件 fp = fopen(filename, "r"); // 如果文件打开失败 ,..., 说明没有文件 if (fp == NULL) { // 以写的方式 , 打开文本文件 , 如果文件不存在 , 则创建文件 fp = fopen(filename

    88630

    c语言爱心代码详解_C语言程序源代码

    1、love图案的C语言爱心代码 C语言爱心代码如下: #include int main() { int i, j, k, n = 0, x = 0, y = 50; //爱心的头部没有规律...printf("e"); y--; } else break; } printf("\n"); } printf("\n\n\n\n\n\n\n\n\n\n\n\n"); return 0; } 已把大量C语言源码整理为一个压缩包关注微...信 公 众 号:“CC加加” 回复:“源码” 即可获取 效果展示: 2、心形图案的C语言爱心代码 代码如下: #include int main() { int i,...m++) printf("%c", c);//输出右半部分字符小爱心 printf("\n"); //每一行输出完毕换行 } for (i=1; i<=3; i++) { //下3行中间没有空格...} 效果展示: 3、复杂动态C语言爱心代码 代码如下: #include #include #include #include <tchar.h

    9.4K21

    C#压缩解压文件处理方案

    Zip文件 /// /// 将指定文件压缩为Zip文件 /// /// 文件地址 D:/1.txt </param...} } 解压Zip文件到指定目录(压缩单个文件的逻辑其实就是先将我们要压缩文件复制到一个临时目录,然后对临时目录执行了压缩动作,压缩完成之后又删除了临时目录) /// /...压缩或解压_WenyueQ°的博客-CSDN博客_c# 解压[3] • .NET中zip的压缩和解压 - Asharp - 博客园[4] • 使用C#和System.IO.Packaging以编程方式从...Zip存档中提取文件 | 码农家园[5] • C# 使用原生 System.IO.Compression 实现 zip 的压缩与解压_大哥手下留情的博客-CSDN博客[6] 引用链接 [1] SharpZipLib...以编程方式从Zip存档中提取文件 | 码农家园: https://www.codenong.com/507751/ [6] C# 使用原生 System.IO.Compression 实现 zip 的压缩与解压

    28710

    C#使用#ziplib压缩和解压缩文件

    要下载整个目录,一般方法是一个个文件下载或ftp工具 现在用SharpZipLib就能实现实时zip压缩下载整个目录 SharpZipLib提供了多种压缩算法的支持,纯csharp代码,参见 http...://www.icsharpcode.net/OpenSource/SharpZipLib/default.asp 原理是通过递归方法将每个文件压缩到ZipOutputStream,然后下载 代码和范例如下...以下为转贴内容: 我在做项目的时候需要将文件进行压缩和解压缩,于是就从http://www.icsharpcode.net/下载了关于压缩和解压缩的源码,但是下载下来后,面对这么多的代码,一时不知如何下手...下面就来解释如何在C#里用http://www.icsharpcode.net/下载的SharpZipLib进行文件压缩和解压缩。 首先需要在项目里引用SharpZipLib.dll。...\unzipped\”;//待压缩文件目录 FileProperties[1]=”C:\zip\a.zip”; //压缩后的目标文件 ZipClass Zc=new ZipClass(

    64820

    C语言文件操作

    什么是文件 在程序设计中,我们谈到的文件一般有两种(从文件功能的角度来分类):程序文件、数据文件 2.1 程序文件 程序文件包括源程序文件(后缀为.c)、目标文件(Windows环境下后缀为.obj,linux...文件名包含三部分:文件路径+文件名主干+文件后缀 例如:C:\code\example.txt 为了方便起见,文件标识通常被称为文件名。...C程序针对文件、画面、键盘等的数据输⼊输出操作都是同流操作的。 一般情况下,我们要想向流里写数据,或者从流中读取数据,都是要打开流,然后操作。...4.1.2 标准流 在C语言程序启动时,会默认打开三个流: ·stdin——标准输入流,在大多数的环境中从键盘输入 ·stdout——标准输出流,在大多数环境中输出到显示器界面 ·stderr——...stdin、stdout、stderr三个流的类型是:FILE*,通常被称为文件指针。 C语言中,就是通过FILE*的文件指针来维护流的各种操作的。

    11410

    C语言文件操作

    本文介绍了C语言中关于文件操作的内容知识,内容较为生涩,没有理解可以多次观看 ---- ---- 一、为什么使用文件 我们在写代码的过程中,有的时候某一些数据我们是想把它保存下来的,而不是说只有在程序运行的时候...他以某些程序设计语言编写,运行于某种目标结构体系上。...举个栗子,程序就如同以英语(程序设计语言)写作的文章,要让一个懂得英语的人(编译器)同时也会阅读这篇文章的人(结构体系)来阅读、理解、标记这篇文章。...,在我们使用完毕之后要关闭文件 ANSI C规定使用fopen和fclose函数来打开和关闭文件,下面是fopen和函数fclose的介绍 我们打开文件的方式,C语言规定有以下几种:...= EOF) // 标准C I/O读取文件循环 { //这里循环的条件就是,读取的字符不是EOF,一直将字符输出 putchar(c); } //文件读取之后结束了,然后判断是什么原因结束的

    3.8K10

    C语言文件操作

    程序⽂件包括源程序⽂件(后缀为.c),⽬标⽂件(windows环境后缀为.obj),可执⾏程序(windows 环境后缀为.exe)。 数据文件是什么?...C程序针对⽂件、画⾯、键盘等的数据输⼊输出操作都是通过流操作的。⼀般情况下,我们要想向流⾥写数据,或者从流中读取数据,都是要打开流,然后操作。...缓冲区的大小根据C编译系统决定的。 因为有缓冲区的存在,C语⾔在操作⽂件的时候,需要做刷新缓冲区或者在⽂件操作结束的时候关闭⽂ 件。 如果不做,可能导致读写⽂件的问题。...在不同的C编译器的FILE类型包含的内容不完全相同,但是⼤同⼩异。 我们可以创建一个文件指针变量 FILE* pf;//⽂件指针变量 定义pf是⼀个指向FILE类型数据的指针变量。...fgets和fputs fgets从流中获取字符串并将其作为C字符串存储到str中,直到读取(num-1)个字符,或者到达换行符或文件结束符,以先发生的为准。

    5210

    C语言文件操作

    程序文件 包括源程序文件(后缀为.c),目标文件(windows环境后缀为.obj),可执行程序(windows环境 后缀为.exe)。 2....,屏幕,网络等等这种外部设备时,对于程序员来说要求太高了,所以抽象出一种 ‘流’ 的概念,程序员只需要把数据写到’ 流 '里面去,至于‘流’中的数据如何传到外部设备,我们不需要关注; 在C语言程序中,会默认打开...3个流: 终端设备-屏幕: 标准输出流 stdout 键盘: 标准输入流 stdin 屏幕: 标准错误流 stderr 代码演示: int...);//c ch = fgetc(pf); printf("%c\n", ch);//d //让文件指针的位置回到文件的起始位置 rewind(pf); //返回文件指针相对于起始位置的偏移量...int main() { FILE* pf = fopen("test.txt", "w"); fputs("abcdef", pf);//先将代码放在输出缓冲区 printf

    10310

    文件操作——C语言

    文件名: 每一个文件都要有一个唯一的文件标识,以便用户识别和引用 一个文件文件名包含三部分:文件路径+文件名主干+文件后缀 就比如 text.txt这样一个文本文件,在电脑D盘C语言中study.c这个文件路径中...D: \ C语言 \ study.c \ text.txt 为了方便,文件标识常被成为文件名。...在C语言程序中对文件、画面、键盘等数据的输入输出操作都是通过流操作的。 一般情况下,我们想要向流里写数据,或者从流中读取数据,都是要打开流,然后操作。...stdin 、 stdout 、stderr 三个流的类型是FILE* , 通常称为文件指针 。 C语言中,就是通过FILE* 的文件指针来维护流的各种操作的。...在我们程序运行的过程中,我们该如何去判断访问一个文件是否访问结束,在C语言中有这样一个函数:feof feof函数 这个函数的作用是:当文件访问结束时,判断访问结束的原因是不是: 遇到文件末尾。

    2910

    C语言 文件操作

    什么时文件        文件用于保存数据,可以做到数据持久化的保存         磁盘上的文件就是文件 但是在程序设计中,文件一般分为两种,程序文件和数据文件         程序文件...包括源程序文件(.c),目标文件(.obj)可执行文件(.exe)         数据文件 文件内容不一定是程序,而是程序运行时读写的数据,比如程序运行需要从中读取数据的文件,或者输出内容的文件....文件名         一个文件要有唯一的文件标识,方便用户识别和引用         文件包括 路径+名字+后缀         例如 C;\a\a.txt         文件标识一般称为文件名        ...C程序针对⽂件、画⾯、键盘等的数据输⼊输出操作都是通过流操作的。 ⼀般情况下,我们要想向流⾥写数据,或者从流中读取数据,都是要打开流,然后操作。         ...标准流          C语言程序在启动的时候,默认打开 stdin stdout stderr三个流,分别是标准输入流,标准输流, 标准错误流.

    8810
    领券