亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? lzw壓縮算法的c語言實現.txt

?? 一個c語言實現的基于字典編碼技術的lzw數據壓縮算法,能正確的實現壓縮和解壓縮
?? TXT
?? 第 1 頁 / 共 2 頁
字號:
 1 程序由五個模塊組成。

(1)  lzw.h      定義了一些基本的數據結構,常量,還有變量的初始化等。

#ifndef __LZW_H__
#define __LZW_H__
//------------------------------------------------------------------------------
#include <stdio.h>
#include <stdlib.h>
#include <windows.h>
#include <memory.h>
//------------------------------------------------------------------------------
#define LZW_BASE    0x102//  The code base
#define CODE_LEN       12   //  Max code length
#define TABLE_LEN      4099 // It must be prime number and bigger than 2^CODE_LEN=4096. 
       // Such as 5051 is also ok.
#define BUFFERSIZE     1024
//------------------------------------------------------------------------------
typedef struct
{
    HANDLE      h_sour;  // Source file handle.
    HANDLE      h_dest;  // Destination file handle.
    
    HANDLE      h_suffix; // Suffix table handle.
    HANDLE      h_prefix; // Prefix table handle.
    HANDLE      h_code;  // Code table handle.
    
    LPWORD      lp_prefix; // Prefix table head pointer.
    LPBYTE      lp_suffix; // Suffix table head pointer.
    LPWORD      lp_code; // Code table head pointer.

    WORD        code;
    WORD        prefix;
    BYTE        suffix;

    BYTE        cur_code_len; // Current code length.[ used in Dynamic-Code-Length mode ]

}LZW_DATA,*PLZW_DATA;


typedef struct
{
    WORD        top;                           84143   03374
    WORD        index;

    LPBYTE      lp_buffer;
    HANDLE      h_buffer;
    
    BYTE        by_left;
    DWORD       dw_buffer;

    BOOL        end_flag;

}BUFFER_DATA,*PBUFFER_DATA;


typedef struct                  //Stack used in decode
{
WORD        index;
HANDLE      h_stack;
LPBYTE      lp_stack;

}STACK_DATA,*PSTACK_DATA;
//------------------------------------------------------------------------------
VOID stack_create( PSTACK_DATA stack )
{
stack->h_stack  = GlobalAlloc( GHND , TABLE_LEN*sizeof(BYTE) );
stack->lp_stack = GlobalLock( stack->h_stack );
stack->index = 0;
}
//------------------------------------------------------------------------------
VOID stack_destory( PSTACK_DATA stack )
{
GlobalUnlock( stack->h_stack );
    GlobalFree  ( stack->h_stack );
}
//------------------------------------------------------------------------------
VOID buffer_create( PBUFFER_DATA    buffer )
{
    buffer->h_buffer   = GlobalAlloc(  GHND,  BUFFERSIZE*sizeof(BYTE)  );
    buffer->lp_buffer  = GlobalLock( buffer->h_buffer );
    buffer->top        = 0;
    buffer->index      = 0;
    buffer->by_left    = 0;
    buffer->dw_buffer  = 0;
    buffer->end_flag   = FALSE;
}
//------------------------------------------------------------------------------
VOID buffer_destory( PBUFFER_DATA   buffer )
{
    GlobalUnlock( buffer->h_buffer );
    GlobalFree  ( buffer->h_buffer );
}
//------------------------------------------------------------------------------
VOID re_init_lzw( PLZW_DATA lzw )    //When code table reached its top it should
{                                    //be reinitialized.      
    memset( lzw->lp_code, 0xFFFF, TABLE_LEN*sizeof(WORD) );
    lzw->code          = LZW_BASE;
    lzw->cur_code_len  = 9;
}
//------------------------------------------------------------------------------
VOID lzw_create(PLZW_DATA    lzw,    HANDLE h_sour,    HANDLE h_dest)
{
WORD i;
    lzw->h_code        = GlobalAlloc( GHND, TABLE_LEN*sizeof(WORD) );
    lzw->h_prefix      = GlobalAlloc( GHND, TABLE_LEN*sizeof(WORD) );
    lzw->h_suffix      = GlobalAlloc( GHND, TABLE_LEN*sizeof(BYTE) );
    lzw->lp_code       = GlobalLock( lzw->h_code   );
    lzw->lp_prefix     = GlobalLock( lzw->h_prefix );
    lzw->lp_suffix     = GlobalLock( lzw->h_suffix );
    lzw->code          = LZW_BASE;
    lzw->cur_code_len  = 9;
    lzw->h_sour        = h_sour;
    lzw->h_dest        = h_dest;
    memset( lzw->lp_code, 0xFFFF, TABLE_LEN*sizeof(WORD) );

}
//------------------------------------------------------------------------------
VOID lzw_destory(PLZW_DATA    lzw)
{  
    GlobalUnlock( lzw->h_code   );
    GlobalUnlock( lzw->h_prefix );
    GlobalUnlock( lzw->h_suffix );

GlobalFree( lzw->h_code  );
    GlobalFree( lzw->h_prefix );
    GlobalFree( lzw->h_suffix );    
}
//------------------------------------------------------------------------------
#endif

(2) fileio.h   定義了一些文件操作

#ifndef __FILEIO_H__
#define __FILEIO_H__
//------------------------------------------------------------------------------
#include <stdio.h>
#include <stdlib.h>
#include <windows.h>
//------------------------------------------------------------------------------
HANDLE  file_handle(CHAR* file_name)
{
    HANDLE h_file;
    h_file = CreateFile(file_name,
                       GENERIC_READ|GENERIC_WRITE,
                       FILE_SHARE_READ|FILE_SHARE_WRITE,
                       NULL,
                       OPEN_ALWAYS,
                       0,
                       NULL
                       );
    return h_file;
}
//------------------------------------------------------------------------------
WORD load_buffer(HANDLE h_sour, PBUFFER_DATA buffer)  // Load file to buffer
{
    DWORD ret;
    ReadFile(h_sour,buffer->lp_buffer,BUFFERSIZE,&ret,NULL);
    buffer->index = 0;
    buffer->top = (WORD)ret;
    return (WORD)ret;
}
//------------------------------------------------------------------------------
WORD empty_buffer( PLZW_DATA lzw, PBUFFER_DATA buffer)// Output buffer to file
{
   
    DWORD ret;
    if(buffer->end_flag) // The flag mark the end of decode
{
  if( buffer->by_left )
  {
   buffer->lp_buffer[ buffer->index++ ] = (BYTE)( buffer->dw_buffer >> 32-buffer->by_left )<<(8-buffer->by_left);
  }
}
WriteFile(lzw->h_dest, buffer->lp_buffer,buffer->index,&ret,NULL);
    buffer->index = 0;
    buffer->top = ret;
    return (WORD)ret;
}
//------------------------------------------------------------------------------
#endif

(3) hash.h  定義了壓縮時所用的碼表操作函數,為了快速查找使用了hash算法,還有處理hash沖突的函數

#ifndef __HASH_H__
#define __HASH_H__
//------------------------------------------------------------------------------
#include <stdio.h>
#include <stdlib.h>
#include <windows.h>
//------------------------------------------------------------------------------
#define   DIV       TABLE_LEN
#define   HASHSTEP  13         // It should bigger than 0.
//------------------------------------------------------------------------------
WORD get_hash_index( PLZW_DATA lzw )
{
    DWORD tmp;
    WORD result;
    DWORD prefix;
    DWORD suffix;
    prefix = lzw->prefix;
    suffix = lzw->suffix;
    tmp = prefix<<8 | suffix;
    result = tmp % DIV;
    return result;
}
//------------------------------------------------------------------------------
WORD re_hash_index( WORD hash ) // If hash conflict occured we must recalculate
{                               // hash index .
    WORD result;
    result = hash + HASHSTEP;
    result = result % DIV;
    return result;
}
//------------------------------------------------------------------------------
BOOL in_table( PLZW_DATA lzw ) // To find whether current code is already in table.
{
    BOOL result;
    WORD hash;

    hash = get_hash_index( lzw );
    if( lzw->lp_code[ hash ] == 0xFFFF )
    {
        result = FALSE;    
    }
    else
    {
        if( lzw->lp_prefix[ hash ] == lzw->prefix &&
            lzw->lp_suffix[ hash ] == lzw->suffix )
        {
            result = TRUE;
        }
        else
        {
            result = FALSE;
            while( lzw->lp_code[ hash ] != 0xFFFF )
            {
                if( lzw->lp_prefix[ hash ] == lzw->prefix &&
                    lzw->lp_suffix[ hash ] == lzw->suffix )
                {
                        result = TRUE;
                        break;    
                }
                hash = re_hash_index( hash );
            }
        }
    }
    return result;
}
//------------------------------------------------------------------------------
WORD get_code( PLZW_DATA lzw )
{
    WORD hash;
    WORD code;
    hash = get_hash_index( lzw );
    if( lzw->lp_prefix[ hash ] == lzw->prefix &&
        lzw->lp_suffix[ hash ] == lzw->suffix )
    {
        code = lzw->lp_code[ hash ];
    }
    else
    {
        while( lzw->lp_prefix[ hash ] != lzw->prefix ||
               lzw->lp_suffix[ hash ] != lzw->suffix )
        {
                hash = re_hash_index( hash );    
        }
        code = lzw->lp_code[ hash ];
    }
    return code;
}
//------------------------------------------------------------------------------
VOID insert_table( PLZW_DATA lzw )
{

    WORD hash;
    hash = get_hash_index( lzw );
    if( lzw->lp_code[ hash ] == 0xFFFF )
    {
        lzw->lp_prefix[ hash ] = lzw->prefix;
        lzw->lp_suffix[ hash ] = lzw->suffix;
        lzw->lp_code[ hash ]   = lzw->code;
    }
    else
    {
        while( lzw->lp_code[ hash ] != 0xFFFF )
        {
                hash = re_hash_index( hash );    
        }
        lzw->lp_prefix[ hash ] = lzw->prefix;
        lzw->lp_suffix[ hash ] = lzw->suffix;
        lzw->lp_code[ hash ]   = lzw->code;
    }

}
//------------------------------------------------------------------------------


#endif

(4) encode.h  壓縮程序主函數

#ifndef __ENCODE_H__
#define __ENCODE_H__
//------------------------------------------------------------------------------
#include <stdio.h>
#include <stdlib.h>
#include <windows.h>

//------------------------------------------------------------------------------

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
午夜成人免费视频| 精品夜夜嗨av一区二区三区| 亚洲精品一区二区三区在线观看 | 99视频一区二区| 国产精品99久久久久久似苏梦涵| 青青青伊人色综合久久| 免费在线一区观看| 国产综合色视频| av中文字幕亚洲| 欧美伊人久久久久久久久影院 | 精品粉嫩aⅴ一区二区三区四区| 欧美群妇大交群中文字幕| 欧美一区二区三区爱爱| 精品少妇一区二区三区| 国产日韩欧美电影| 亚洲另类在线制服丝袜| 午夜精品123| 国产精品亚洲成人| 97超碰欧美中文字幕| 欧美日韩精品一区二区在线播放| 欧美日韩在线免费视频| 亚洲精品在线电影| 亚洲欧美自拍偷拍色图| 亚洲高清免费一级二级三级| 美女视频第一区二区三区免费观看网站| 老司机一区二区| 97久久超碰精品国产| 欧美日韩国产免费一区二区| 久久免费视频色| 一区二区三区久久| 黑人巨大精品欧美黑白配亚洲| 99久久综合色| 日韩免费成人网| 亚洲天堂a在线| 国内精品在线播放| 在线亚洲一区观看| 久久久精品人体av艺术| 亚洲五月六月丁香激情| 国产精品亚洲成人| 4438成人网| 亚洲色图丝袜美腿| 国产资源精品在线观看| 欧美色图第一页| 国产精品欧美经典| 卡一卡二国产精品| 欧美三级资源在线| 亚洲同性同志一二三专区| 日本sm残虐另类| 欧洲人成人精品| 18欧美亚洲精品| 国内精品嫩模私拍在线| 欧洲av在线精品| 最新高清无码专区| 国产成人精品1024| 日韩欧美一级精品久久| 亚洲激情自拍偷拍| av电影在线不卡| 国产香蕉久久精品综合网| 日韩中文字幕av电影| 99精品国产91久久久久久| 国产清纯美女被跳蛋高潮一区二区久久w | 欧美一区二区不卡视频| 亚洲精品视频观看| 91网站在线播放| 欧美国产视频在线| 国内精品伊人久久久久av影院| 91.成人天堂一区| 亚洲一区二区欧美| 91丝袜国产在线播放| 欧美国产97人人爽人人喊| 国产麻豆视频一区| 欧美变态口味重另类| 免费成人在线视频观看| 欧美乱熟臀69xxxxxx| 亚洲线精品一区二区三区八戒| 91麻豆自制传媒国产之光| 日韩一区在线看| 一本到三区不卡视频| 亚洲女性喷水在线观看一区| 91视频91自| 亚洲最大成人网4388xx| 欧美亚洲一区三区| 亚洲一区二区三区四区在线观看 | 午夜精品福利久久久| 欧美日韩国产三级| 日韩电影在线看| 欧美久久免费观看| 日韩av电影免费观看高清完整版在线观看| 欧美日韩一区二区欧美激情| 亚洲丰满少妇videoshd| 欧美精品一卡二卡| 奇米四色…亚洲| 久久久亚洲综合| 波多野结衣亚洲| 亚洲黄色片在线观看| 欧美日韩五月天| 奇米色777欧美一区二区| 欧美精品一区二区精品网| 国产成人一级电影| 亚洲欧洲日本在线| 欧美日韩国产在线播放网站| 日本三级亚洲精品| 国产精品你懂的| 欧美视频精品在线观看| 青青草精品视频| 日本一区二区三区电影| 色欧美88888久久久久久影院| 日日摸夜夜添夜夜添亚洲女人| 精品日本一线二线三线不卡| 成人精品视频一区二区三区 | 欧美大片在线观看| 成人国产精品视频| 日日夜夜精品免费视频| 国产亚洲一区字幕| 欧美另类高清zo欧美| 国产一区二区三区综合| 伊人开心综合网| 久久蜜桃香蕉精品一区二区三区| 91网上在线视频| 久久99国产精品免费网站| 国产精品日韩精品欧美在线| 欧美丝袜丝nylons| 风间由美性色一区二区三区| 丝袜美腿亚洲综合| 亚洲天堂2014| 久久麻豆一区二区| 91精品国产91久久久久久一区二区| 国产成人自拍在线| 日韩电影在线观看电影| 亚洲精品中文在线影院| 国产亚洲成av人在线观看导航| 911精品国产一区二区在线| 99热这里都是精品| 国产黄人亚洲片| 久久66热偷产精品| 天堂午夜影视日韩欧美一区二区| 亚洲欧美偷拍三级| 国产精品私人影院| 国产日韩亚洲欧美综合| 欧美成人a在线| 日韩一区二区精品| 欧美日韩美女一区二区| 91传媒视频在线播放| 91麻豆国产香蕉久久精品| 懂色av一区二区在线播放| 老司机精品视频在线| 三级亚洲高清视频| 日本sm残虐另类| 全部av―极品视觉盛宴亚洲| 婷婷丁香激情综合| 天堂一区二区在线| 日本va欧美va瓶| 久久不见久久见免费视频7| 日本不卡中文字幕| 日韩vs国产vs欧美| 日本v片在线高清不卡在线观看| 午夜精品爽啪视频| 男人操女人的视频在线观看欧美| 秋霞成人午夜伦在线观看| 秋霞影院一区二区| 狠狠色狠狠色合久久伊人| 国产一区二区三区不卡在线观看 | 亚洲h精品动漫在线观看| 亚洲午夜精品一区二区三区他趣| 亚洲高清视频在线| 日韩电影免费一区| 国产真实乱子伦精品视频| 国产精品99久久久久| av电影天堂一区二区在线| 91麻豆国产香蕉久久精品| 欧美日韩午夜影院| 精品99999| 日本一区二区久久| 亚洲自拍偷拍综合| 日韩福利电影在线| 国产91在线看| 在线视频欧美精品| 日韩欧美成人激情| 国产精品国产三级国产aⅴ无密码 国产精品国产三级国产aⅴ原创 | 综合久久国产九一剧情麻豆| 亚洲色图色小说| 无码av免费一区二区三区试看| 免费高清视频精品| 不卡的电影网站| 欧美视频在线不卡| 欧美国产成人精品| 亚洲高清在线精品| 国产91精品在线观看| 欧洲另类一二三四区| 欧美刺激脚交jootjob| 中文字幕一区免费在线观看| 亚洲香肠在线观看| 国产91高潮流白浆在线麻豆| 色婷婷狠狠综合| 26uuu另类欧美| 亚洲成a人片在线观看中文| 国产激情一区二区三区四区 | 日韩激情av在线| 91视视频在线直接观看在线看网页在线看| 欧美日韩一区二区三区四区|