首页
学习
活动
专区
工具
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.4K20

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

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

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

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

    9.4K10

    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 的压缩与解压

    30010

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

    以下为转贴内容: 我在做项目的时候需要将文件进行压缩和解压缩,于是就从http://www.icsharpcode.net/下载了关于压缩和解压缩的源码,但是下载下来后,面对这么多的代码,一时不知如何下手...针对自己的需要改写了文件压缩和解压缩的两个类,分别为ZipClass和UnZipClass。...下面就来解释如何在C#里用http://www.icsharpcode.net/下载的SharpZipLib进行文件压缩和解压缩。 首先需要在项目里引用SharpZipLib.dll。...\unzipped\”;//待压缩文件目录 FileProperties[1]=”C:\zip\a.zip”; //压缩后的目标文件 ZipClass Zc=new ZipClass(...\zip\test.zip”;//待解压的文件 FileProperties[1]=”C:\unzipped\”;//解压后放置的目标目录 UnZipClass UnZc=new UnZipClass

    65620

    C语言-文件操作

    二进制文件和文本文件 2.1 数据⽂件 在C语言文件操作中主要学习的是对于数据文件的操作 数据文件不是用来保存程序的,而是用来保存程序运行后产生的数据 2.2 文本文件 文本文件是以人类可读的字符形式存储数据的文件...在C语言中,使用标准的文件I/O函数(比如fprintf、fscanf、fgets、fputs等)来处理文本文件是很方便的。这些函数可以直接读取和写入文本文件中的文本数据,并且适合于处理文本内容。...由于二进制文件不以人类可读的形式存储数据,它们无法直接用文本编辑器打开和阅读。 在C语言中,处理二进制文件需要使用fread和fwrite等函数,这些函数可以直接读取和写入二进制数据。...在C语言中,流是以FILE结构表示的,每个流都对应着一个FILE类型的指针。通过这个指针,程序可以访问流的属性和进行读写操作。...3.1.2 标准流 在C语言中,标准库提供了一组预定义的流,称为标准流(standard streams),它们包括标准输入流(stdin)、标准输出流(stdout)和标准错误流(stderr)。

    8910

    C语言-文件编程

    文件编程函数介绍 如果在Linux系统下学习C语言,就会了解到两套文件编程接口函数: C语言标准的文件编程函数: fopen*、fread、fwrite、*fclose Linux下提供的文件编程函数:...C语言标准库提供的文件编程函数 下面介绍C语言标准库提供的文件编程函数,一般对文件常用的操作就是:创建(打开)、读、写、关闭。...--小整数)文件打开成功值>=0 否则<0 示例: open("123.c",O_RDWR|O_CREAT,S_IRWXU|S_IRWXG|S_IRWXO); 创建一个123.c的新文件,并且指定该文件的权限是最高权限...int close(int fd); 函数功能: 关闭已经打开的文件. 4. 案例: 实现文件拷贝功能(fopen) 例如: cp 123.c 456.c 将123.c的数据拷贝到456.c文件里。...案例: 实现文件拷贝功能(open) 例如: cp 123.c 456.c 将123.c的数据拷贝到456.c文件里。

    12.9K31

    C语言文件(windows)

    文件的概念(流 文件 缓冲区),文件的打开,文件的关闭,读写文件(字符、二进制)(顺序 随机) 文件:程序文件(.c .cpp .java .exe);数据文件(.dat) 广义的文件:程序数据输出到磁盘或其他外部设备...,称为文件。...在C语言中,把文件可以看作一个字符(或字节)的序列,即由一个一个字符(字节)的数据顺序组成的。一个输入输出流就是一个字符流或字节流。...文件名:文件名是由3部分组成的(D:\DD\TEMP\file.dat) 文件的路径 文件名主干 文件的后缀名 文件缓冲区 是指文件系统会自带在内存中为程序的每一个文件开辟一个文件的缓冲区。...从内存向磁盘输出数据时,必须先将数据发送到文件缓冲区中,在文件缓冲区装满后才一起将数据输出到磁盘。 文件指针:表示一个可以指向文件的指针。int *p

    2.3K20

    C语言 | 文件概述

    C语言什么是文件 文件有不同的类型,在程序设计中,主要用到两种文件: 程序文件:包括源程序文件(后缀为.c)、目标文件(后缀为.obj)、可执行文件(后缀为.exe)等。这种文件的内容时程序代码。...C语言文件名 一个文件要有一个唯一的文件标识,以便用户识别和引用。...C语言文件缓冲区 ANSI C标准采用“缓冲文件系统”处理数据文件,所谓缓冲文件系统是指系统自动地在内存区为程序中每一个正在使用的文件开辟一个文件缓冲区。...以上,如果你看了觉得对你有所帮助,就给小林点个赞,分享给身边的人叭,这样小林也有更新下去的动力,跪谢各位父老乡亲啦~ C语言学习路线    C语言开发工具 VC6.0、Devc++、VS2019使用教程...100道C语言源码案例请去公众号:C语言入门到精通

    2.6K00

    C语言文件操作

    之前经常遇到C语言文件的操作,经常因奇奇怪怪的函数而感到一头雾水,终于今晚有幸上了下程序设计基础课,对文件的操作有了一次系统性学习的体验,下面就稍作记录,以便查阅 文件类型指针 typedef struct...fclose(fp); 顺序读写数据文件 读写字符 读写字符串 用格式化的方式读写文本文件 fprintf(文件指针, 格式字符串, 输出表列); fscanf(文件指针, 格式字符串...例如: float f[10]; fread(f,4,10,fp); //从fp所指向的文件读入10个4个字节的数据,存储到数组f中 随机读写数据文件 rewind(文件指针); 使文件位置标记指向文件开头...,无返回值 fseek(文件类型指针, 位移量, 起始点); 用fseek函数改变文件位置标记 “起始点”:用0,1或2代替,0代表“文件开始位置”,1为“当前位置”,2为“文件末尾位置” “位移量...”:指以“起始点”为基点,向前移动的字节数(长整型) 例如: 用ftell函数测定文件位置标记的当前位置 ftell函数的作用是得到流式文件文件位置标记的当前位置,用相对于文件开头的位移量来表示

    2.9K20

    C语言 | 文件概述

    “要成为绝世高手,并非一朝一夕,除非是天生武学奇才,但是这种人…万中无一” ——包租婆 这道理放在C语言学习上也一并受用。...在编程方面有着天赋异禀的人毕竟是少数,我们大多数人想要从C语言小白进阶到高手,需要经历的是日积月累的学习。 那么如何学习呢?当然是每天都练习一道C语言题目!! ? 作者 闫小林 白天搬砖,晚上做梦。...C语言什么是文件 文件有不同的类型,在程序设计中,主要用到两种文件: 程序文件:包括源程序文件(后缀为.c)、目标文件(后缀为.obj)、可执行文件(后缀为.exe)等。这种文件的内容时程序代码。...C语言文件名 一个文件要有一个唯一的文件标识,以便用户识别和引用。...C语言文件缓冲区 ANSI C标准采用“缓冲文件系统”处理数据文件,所谓缓冲文件系统是指系统自动地在内存区为程序中每一个正在使用的文件开辟一个文件缓冲区。

    2.8K20

    C语言---头文件

    声明一下:以下源文件就是.c文件,头文件就是.h文件。 编程规范规定,头文件里面不能include其他文件,只能在源文件中include使用到的头文件,防止头文件重复包含。...这样就可以正常使用了,如果头文件不包含头文件的话,只在源文件中包含,这样能使用吗?会不会报错? 例如:源文件mian.c中包含了头文件a.h和b.h,头文件b.h中需要引用a.h中的数据结构类型。...SRU_S类型并没有在b.h中定义,也没有包含有定义此结构体的文件。然后我们在main.c中使用b.h中的结构。...test_include$ gcc main.c hehk@hehk:~/test/C/test_include$ ..../a.out sb.b: 1 sb.sa.a: 99 如果我们main.c中的头文件包含a.h和b.h的位置调换一下,先包含b.h再包含a.h。

    4K20

    C语言文件操作

    在程序设计中,我们所讨论的文件从功能的角度划分为两种:程序文件、数据文件 程序文件:包括源程序文件(后缀为.c),目标文件(windows环境后缀为.obj),可执行程序(windows环境后缀为.exe...'c'到文件里面去 #include int main() { //打开文件 FILE* pf = fopen("test.txt", "w");//我们要写数据进去 if...('c', pf); fclose(pf);//关闭文件 pf = NULL;//置空 return 0; } 此时没有发生任何错误,成功写入,这里,每一次调用这个函数,文件的光标就会自动后移...比如我们还是从"test.txt"这个文件中读,此代码只写读文件的部分,打开文件和关闭文件跟上面是一样的,替换一下就好了 //读文件 int ch = fgetc(pf); printf("%c",...ch); ch = fgetc(pf); printf("%c", ch); ch = fgetc(pf); printf("%c", ch); 读文件,然后打印出来 如果想读文件中所有内容,可以用循环

    9010

    C语言 | 读写文件

    C语言怎样向文件读写字符 fgetc函数 调用形式:fgetc(fp) 功能:从fp指向的文件读入一个字符。 返回值:读成功,带回所读的字符,失败则返回文件结束标志EOF(即-1)。...C语言怎样向文件读写一个字符串 fgets函数 调用形式:fgets(str,n,fp) 功能:从fp指向的文件读入一个长度为(n-1)的字符串,存放到字符数组str中。...C语言用格式化的方式读写文件文件进行格式化输入输出时,要用fprintf函数和fscanf函数,作用与printf函数和scanf函数相仿,都是格式化读写函数。...一般形式 fprintf(文件指针,格式字符串,输出表列); fscanf(文件指针,格式字符串,输入表列); C语言用二进制方式向文件读写一组数据 C语言允许用fread函数从文件中读一个数据块,用...100道C语言源码案例请去公众号:C语言入门到精通

    3.4K00

    C语言文件操作

    程序文件 包括源程序文件(后缀为.c),目标文件(windows环境后缀为.obj),可执行程序(windows环境 后缀为.exe)。 2....,屏幕,网络等等这种外部设备时,对于程序员来说要求太高了,所以抽象出一种 ‘流’ 的概念,程序员只需要把数据写到’ 流 '里面去,至于‘流’中的数据如何传到外部设备,我们不需要关注; 在C语言程序中,会默认打开...("%c\n", ch);//b ch = fgetc(pf); printf("%c\n", ch);//c ch = fgetc(pf); printf("%c\n", ch...("%c\n", ch);//a ch = fgetc(pf); printf("%c\n", ch);//b ch = fgetc(pf); printf("%c\n", ch...);//c ch = fgetc(pf); printf("%c\n", ch);//d //让文件指针的位置回到文件的起始位置 rewind(pf); //返回文件指针相对于起始位置的偏移量

    10510
    领券