在C语言中,对数据集进行压缩可以通过多种算法来实现,例如LZ77、Huffman编码、Lempel-Ziv-Welch (LZW)等。以下是一个使用LZ77算法进行数据压缩的简单示例:
liblzip
。在Debian/Ubuntu系统上,可以使用以下命令安装:sudo apt-get install liblzip-dev
在macOS上,可以使用Homebrew安装:
brew install lzip
compress.c
,并添加以下代码:#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <lzip/lzip.h>
void compress(const char *input_file, const char *output_file) {
FILE *input = fopen(input_file, "rb");
if (!input) {
perror("Error opening input file");
return;
}
FILE *output = fopen(output_file, "wb");
if (!output) {
perror("Error opening output file");
fclose(input);
return;
}
lzip_file *lf = lzip_open(input, LZIP_OPT_BESTSPEED);
if (!lf) {
perror("Error opening lzip file");
fclose(input);
fclose(output);
return;
}
unsigned char buffer[65536];
size_t read;
size_t compressed_size = 0;
while ((read = lzip_read(lf, buffer, sizeof(buffer))) > 0) {
size_t written = fwrite(buffer, 1, read, output);
if (written != read) {
perror("Error writing to output file");
lzip_close(lf);
fclose(input);
fclose(output);
return;
}
compressed_size += read;
}
if (lzip_close(lf) != 0) {
perror("Error closing lzip file");
fclose(input);
fclose(output);
return;
}
printf("Compressed size: %zu bytes\n", compressed_size);
fclose(input);
fclose(output);
}
int main() {
compress("input.txt", "output.lz");
return 0;
}
gcc compress.c -o compress -llzip
./compress
这将压缩input.txt
文件并将其保存为output.lz
。
请注意,这只是一个简单的示例,实际应用中可能需要根据具体需求对算法进行调整。另外,压缩和解压缩数据通常需要相应的库支持,因此在选择压缩方法时要考虑库的可用性和性能。