movetofront.cpp
来自「My (so called) HiP compression algorithm」· C++ 代码 · 共 60 行
CPP
60 行
#include "movetofront.h"
void MoveToFront::Encode( PBYTE buffer, DWORD cb )
{
BYTE byTbl[256];
// initialize table
for ( UINT u = 0; u < 256; u++ )
byTbl[u] = u;
// process input buffer
for ( UINT c = 0; c < cb; c++ )
{
// find symbol in table
for ( UINT i = 0; ; i++ )
if ( byTbl[i] == *buffer )
break;
UINT index = i;
// move table items til index by 1 position
for ( ; i != 0; --i )
byTbl[i] = byTbl[i - 1];
byTbl[0] = *buffer;
*buffer = index;
// inc ptr
++buffer;
}
return;
}
void MoveToFront::Decode( PBYTE buffer, DWORD cb )
{
BYTE byTbl[256];
// initialize table
for ( UINT u = 0; u < 256; u++ )
byTbl[u] = u;
// process input buffer
for ( UINT c = 0; c < cb; c++ )
{
BYTE by = byTbl[*buffer];
// move table items til index by 1 position
for ( UINT i = *buffer ; i != 0; --i )
byTbl[i] = byTbl[i - 1];
byTbl[0] = by;
*buffer = by;
// inc ptr
++buffer;
}
return;
}
⌨️ 快捷键说明
复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?