资源简介
基于lz77的c语言代码 直接运行即可 直接往源文件.txt中输入信息,在压缩文件和解压文件中即有相应显示

代码片段和文件信息
#include
#include
#include
#include
#include
#define OFFSET_CODING_LENGTH (10)
#define MAX_WND_SIZE 1024
#define OFFSET_MASK_CODE (MAX_WND_SIZE-1)
const ULONG m=3;
UCHAR __buffer1__[0x200000];
UCHAR __buffer2__[0x200000];
void
Write1ToBitStream(
PUCHAR pBuffer
ULONG ulBitOffset
)
{
ULONG ulByteBoundary;
ULONG ulOffsetInByte;
ulByteBoundary = ulBitOffset>>3 ;
ulOffsetInByte = ulBitOffset&7;
*(pBuffer+ulByteBoundary) |= (1< }
void
Write0ToBitStream(
PUCHAR pBuffer
ULONG ulBitOffset
)
{
ULONG ulByteBoundary;
ULONG ulOffsetInByte;
ulByteBoundary = ulBitOffset>>3 ;
ulOffsetInByte = ulBitOffset&7;
*(pBuffer+ulByteBoundary) &= (~(1< }
ULONG
ReadBitFromBitStream(
PUCHAR pBuffer
ULONG ulBitOffset
)
{
ULONG ulByteBoundary;
ULONG ulOffsetInByte;
ulByteBoundary = ulBitOffset>>3 ;
ulOffsetInByte = ulBitOffset&7;
return ((*(PULONG)(pBuffer+ulByteBoundary))>>ulOffsetInByte)&1 ;
}
ULONG WINAPI
WriteGolombCode(
ULONG x
PUCHAR pBuffer
ULONG ulBitOffset
)
{
ULONG q r;
int i;
q = (x-1)>>m;
r = x-(q<
for(i=0; (ULONG)i {
Write1ToBitStream(pBuffer ulBitOffset);
}
Write0ToBitStream(pBuffer ulBitOffset);
ulBitOffset++;
for(i=0; i {
if( (r>>i)&1 )
{
Write1ToBitStream(pBuffer ulBitOffset);
}
else
{
Write0ToBitStream(pBuffer ulBitOffset);
}
}
return m+q+1;
}
ULONG
ReadGolombCode(
PULONG pulCodingLength
PUCHAR pBuffer
ULONG ulBitOffset
)
{
ULONG q r;
ULONG bit;
int i;
for(q=0; ;q++)
{
bit = (ULONG)ReadBitFromBitStream(pBuffer ulBitOffset);
ulBitOffset++;
if( !bit )
{
break;
}
}
for(i=0 r=0; (ULONG)i {
bit = (ULONG)ReadBitFromBitStream(pBuffer ulBitOffset);
bit <<= i;
r |= bit;
}
*pulCodingLength = m + q + 1;
return r+(q< }
ULONG
CompareStrings(
PUCHAR string1
PUCHAR string2
ULONG length
)
{
ULONG i;
PUCHAR p1 p2;
p1 = string1;
p2 = string2;
for(i=0; i {
if( *p1==*p2 )
{
p1++;
p2++;
}
else
{
break;
}
}
return p1-string1;
}
void WINAPI
FindLongestSubstring(
PUCHAR pSourceString
PUCHAR pString
ULONG ulSourceStringLength
PULONG pulSubstringOffset
PULONG pulSubstringLength
)
{
PUCHAR pSrc;
ULONG offset length;
ULONG
属性 大小 日期 时间 名称
----------- --------- ---------- ----- ----
目录 0 2014-04-11 12:44 完成版lz77程序\
目录 0 2014-04-11 12:44 完成版lz77程序\Debug\
文件 233525 2014-04-11 12:31 完成版lz77程序\Debug\lz77.exe
文件 273464 2014-04-11 12:31 完成版lz77程序\Debug\lz77.ilk
文件 30226 2014-04-11 12:31 完成版lz77程序\Debug\lz77.obj
文件 3627720 2014-04-11 12:18 完成版lz77程序\Debug\lz77.pch
文件 574464 2014-04-11 12:31 完成版lz77程序\Debug\lz77.pdb
文件 156672 2014-04-11 12:44 完成版lz77程序\Debug\vc60.idb
文件 86016 2014-04-11 12:31 完成版lz77程序\Debug\vc60.pdb
文件 11772 2014-04-11 12:31 完成版lz77程序\lz77.cpp
文件 3377 2014-04-11 12:44 完成版lz77程序\lz77.dsp
文件 516 2014-04-11 12:44 完成版lz77程序\lz77.dsw
文件 50176 2014-04-11 12:44 完成版lz77程序\lz77.ncb
文件 48640 2014-04-11 12:44 完成版lz77程序\lz77.opt
文件 242 2014-04-11 12:44 完成版lz77程序\lz77.plg
文件 0 2014-04-11 12:45 完成版lz77程序\压缩文件.txt
文件 0 2014-04-11 12:45 完成版lz77程序\源文件.txt
文件 0 2014-04-11 12:45 完成版lz77程序\解压文件.txt
相关资源
- C++获取计算机的CPU ID,硬盘序列号等
- C++头文件转delphi工具 + 源码
- C语言编程常见问题解答.pdf
- GD32通过规则组寄存器 DMA获取多组AD
- 基于MFC的TCP调试助手源码95706
- 国际象棋的qt源代码
- 操作系统c语言模拟文件管理系统844
- C语言开发实战宝典
- C++中头文件与源文件的作用详解
- 基于mfc的多线程文件传输
- C++多线程网络编程Socket
- VC++ 多线程文件读写操作
- C语言代码高亮html输出工具
- 猜数字游戏 c语言代码
- C语言课程设计
- 数字电位器C语言程序
- CCS FFT c语言算法
- 使用C语言编写的病房管理系统
- 通信过程中的RS编译码程序(c语言)
- 利用C++哈希表的方法实现电话号码查
- 计算机二级C语言上机填空,改错,编
- 用回溯法解决八皇后问题C语言实现
- 移木块游戏,可以自编自玩,vc6.0编写
- 简易教务管理系统c语言开发文档
- 操作系统课设 读写者问题 c语言实现
- 小波变换算法 c语言版
- C流程图生成器,用C语言代码 生成C语
- 3des加密算法C语言实现
- 简单的C语言点对点聊天程序
- 单片机c语言源程序(51定时器 八个按
评论
共有 条评论