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

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

?? lzw算法的實現.txt

?? LZW算法的C語言實現!能夠實現對原始數據的壓縮!
?? TXT
?? 第 1 頁 / 共 2 頁
字號:
     out->dw_buffer |= code << ( 32 - out->by_left - lzw->cur_code_len );
     out->by_left += lzw->cur_code_len;

     while( out->by_left >= 8 )
     {
         if( out->index == BUFFERSIZE )
         {
             empty_buffer( lzw,out);
         }

         out->lp_buffer[ out->index++ ] = (BYTE)( out->dw_buffer >> 24 );
         out->dw_buffer <<= 8;
         out->by_left -= 8;
     }
}
//------------------------------------------------------------------------------
VOID do_encode( PBUFFER_DATA in, PBUFFER_DATA out, PLZW_DATA lzw)
{
     WORD prefix;
     while( in->index != in->top )
     {
         if( !in_table(lzw) )
         {
                 // current code not in code table
                 // then add it to table and output prefix


                 insert_table(lzw);
                 prefix = lzw->suffix;
                 output_code( lzw->prefix ,out ,lzw );
                 lzw->code++;

                 if( lzw->code == (WORD)1<< lzw->cur_code_len )
                 {
                     // code reached current code top(1<<cur_code_len)
                     // then current code length add one
      lzw->cur_code_len++;
      if( lzw->cur_code_len == CODE_LEN + 1 )
      {
       re_init_lzw( lzw );
      }

                 }
         }
         else
         {
                 // current code already in code table 
                 // then output nothing
                 prefix = get_code(lzw);

         }
         lzw->prefix = prefix;
         lzw->suffix = in->lp_buffer[ in->index++ ];
     }
}

//------------------------------------------------------------------------------
VOID encode(HANDLE h_sour,HANDLE h_dest)
{
     LZW_DATA         lzw;
     BUFFER_DATA      in ;
     BUFFER_DATA      out;
    
     BOOL first_run = TRUE;

     lzw_create( &lzw ,h_sour,h_dest );
     buffer_create( &in );
     buffer_create( &out );


     while( load_buffer( h_sour, &in ) )
     {
         if( first_run )
         {// File length should be considered   but here we simply 
          // believe file length bigger than 2 bytes.
                 lzw.prefix = in.lp_buffer[ in.index++ ];
                 lzw.suffix = in.lp_buffer[ in.index++ ];
                 first_run = FALSE;
         }
         do_encode(&in , &out, &lzw);
     }
    
output_code(lzw.prefix, &out , &lzw);
output_code(lzw.suffix, &out , &lzw);
out.end_flag = TRUE;
     empty_buffer( &lzw,&out);

     lzw_destory( &lzw );
     buffer_destory( &in );
     buffer_destory( &out );
}

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

#endif

(5) decode.h   解壓函數主函數

#ifndef __DECODE_H__
#define __DECODE_H__
//------------------------------------------------------------------------------
#include <stdio.h>
#include <stdlib.h>
#include <windows.h>
//------------------------------------------------------------------------------
VOID out_code( WORD code ,PBUFFER_DATA buffer,PLZW_DATA lzw,PSTACK_DATA stack)
{
WORD tmp;
if( code < 0x100 )
{
   stack->lp_stack[ stack->index++ ] = code;
}
else
{
    stack->lp_stack[ stack->index++ ] = lzw->lp_suffix[ code ];
    tmp = lzw->lp_prefix[ code ];
    while( tmp > 0x100 )
    {
     stack->lp_stack[ stack->index++ ] = lzw->lp_suffix[ tmp ];
     tmp = lzw->lp_prefix[ tmp ];
    }
    stack->lp_stack[ stack->index++ ] = (BYTE)tmp;

}


while( stack->index )
{
   if( buffer->index == BUFFERSIZE )
   {
    empty_buffer(lzw,buffer);
   }
   buffer->lp_buffer[ buffer->index++ ] = stack->lp_stack[ --stack->index ] ;
}
}
//------------------------------------------------------------------------------
VOID insert_2_table(PLZW_DATA lzw )
{

lzw->lp_code[ lzw->code ]    = lzw->code;
lzw->lp_prefix[ lzw->code ] = lzw->prefix;
lzw->lp_suffix[ lzw->code ] = lzw->suffix;
lzw->code++;

if( lzw->code == ((WORD)1<<lzw->cur_code_len)-1 )
{
   lzw->cur_code_len++;
   if( lzw->cur_code_len == CODE_LEN+1 )
       lzw->cur_code_len = 9;
}
if(lzw->code >= 1<<CODE_LEN )
{
   re_init_lzw(lzw);
}

}
//------------------------------------------------------------------------------
WORD get_next_code( PBUFFER_DATA buffer , PLZW_DATA lzw )
{

BYTE next;
WORD code;
while( buffer->by_left < lzw->cur_code_len )
{
   if( buffer->index == BUFFERSIZE )
   {
    load_buffer( lzw->h_sour, buffer );
   }
   next = buffer->lp_buffer[ buffer->index++ ];
   buffer->dw_buffer |= (DWORD)next << (24-buffer->by_left);
   buffer->by_left    += 8;
}
code = buffer->dw_buffer >> ( 32 - lzw->cur_code_len );
buffer->dw_buffer <<= lzw->cur_code_len;
buffer->by_left     -= lzw->cur_code_len;

return code;
}
//------------------------------------------------------------------------------
VOID do_decode( PBUFFER_DATA in, PBUFFER_DATA out, PLZW_DATA lzw, PSTACK_DATA stack)
{
WORD code;
WORD tmp;
while( in->index != in->top   )
{
   code = get_next_code( in ,lzw );

   if( code < 0x100 )
   {
    // code already in table 
    // then simply output the code
    lzw->suffix = (BYTE)code;
   }
   else 
   {
    if( code < lzw->code   )
    {
     // code also in table 
     // then output code chain
    
     tmp = lzw->lp_prefix[ code ];
     while( tmp > 0x100 )
     {
      tmp = lzw->lp_prefix[ tmp ];
     }
     lzw->suffix = (BYTE)tmp;
    }
    else
    {
     // code == lzw->code
     // code not in table
     // add code into table
     // and out put code 
     tmp = lzw->prefix;
     while( tmp > 0x100 )
     {
      tmp = lzw->lp_prefix[ tmp ];
     }
     lzw->suffix = (BYTE)tmp;
    }
   }
   insert_2_table( lzw );
   out_code(code,out,lzw,stack);

   lzw->prefix = code;

}

}
//------------------------------------------------------------------------------
VOID decode( HANDLE h_sour, HANDLE h_dest )
{
     LZW_DATA         lzw;
     BUFFER_DATA      in ;
     BUFFER_DATA      out;
STACK_DATA       stack;
BOOL    first_run;

first_run = TRUE;


     lzw_create( &lzw ,h_sour,h_dest );
     buffer_create( &in );
     buffer_create( &out );
stack_create(&stack );

     while( load_buffer( h_sour, &in ) )
     {
   if( first_run )
   {
    lzw.prefix = get_next_code( &in, &lzw );
    lzw.suffix = lzw.prefix;
    out_code(lzw.prefix, &out, &lzw , &stack);
    first_run = FALSE;
   }
         do_decode(&in , &out, &lzw, &stack);
     }

     empty_buffer( &lzw,&out);

     lzw_destory( &lzw );
     buffer_destory( &in );
     buffer_destory( &out );
stack_destory( &stack);
}

#endif

2   下面給出一個應用上面模塊的簡單例子

#include <stdio.h>
#include <stdlib.h>
//------------------------------------------------------------------------------

#include "lzw.h"
#include "hash.h"
#include "fileio.h"
#include "encode.h"
#include "decode.h"

//------------------------------------------------------------------------------
HANDLE h_file_sour;  
HANDLE h_file_dest;
HANDLE h_file;
CHAR*   file_name_in = "d:\\code.c";
CHAR*   file_name_out= "d:\\encode.e";
CHAR*   file_name     = "d:\\decode.d";


//------------------------------------------------------------------------------
int main(int argc, char *argv[]) 
{
     h_file_sour = file_handle(file_name_in);
     h_file_dest = file_handle(file_name_out);
     h_file      = file_handle(file_name);


   encode(h_file_sour, h_file_dest);  
// decode(h_file_dest,h_file); 


     CloseHandle(h_file_sour); 
     CloseHandle(h_file_dest);  
     CloseHandle(h_file);

   return 0;      
}    

3   
 

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美体内she精高潮| 视频一区二区三区在线| 日本乱人伦一区| 国产aⅴ综合色| 国产成人av自拍| 黄色资源网久久资源365| 蜜臀91精品一区二区三区| 日韩精品电影一区亚洲| 午夜一区二区三区在线观看| 亚洲卡通欧美制服中文| 一区二区在线观看免费视频播放| 中国色在线观看另类| 中文一区二区在线观看| 日韩一区有码在线| 亚洲色图欧美偷拍| 亚洲日本欧美天堂| 一区二区三区四区五区视频在线观看 | 亚洲欧美日韩久久| 亚洲天堂网中文字| 丝袜亚洲精品中文字幕一区| 日韩国产欧美在线观看| 麻豆成人在线观看| 国产不卡视频在线观看| 99精品视频一区二区三区| 91搞黄在线观看| 欧美日本在线播放| 久久影院午夜片一区| 国产精品午夜久久| 亚洲成av人片在www色猫咪| 久久激情综合网| 91色.com| 欧美成人免费网站| 亚洲欧美怡红院| 午夜成人免费电影| 国产福利一区在线观看| 91成人免费网站| 亚洲欧洲一区二区在线播放| 亚洲一区二区视频| 国内不卡的二区三区中文字幕 | 一区二区三区国产豹纹内裤在线| 喷白浆一区二区| 91色|porny| 亚洲精品一区二区精华| 亚洲免费在线观看视频| 国产一区在线观看麻豆| 欧美日韩亚洲综合在线| 国产女主播在线一区二区| 亚洲一二三四在线| 国精产品一区一区三区mba视频| 一本到不卡精品视频在线观看| 精品国产污网站| 偷拍亚洲欧洲综合| 一本久久精品一区二区 | 92国产精品观看| 精品国产乱码久久久久久久 | 欧美日本一区二区| 亚洲精品欧美二区三区中文字幕| 国产精品中文字幕欧美| 一本到三区不卡视频| 国产亚洲人成网站| 免费精品视频在线| 欧美精品一级二级| 一区二区三区欧美久久| 成人午夜免费av| 国产欧美日韩视频一区二区| 精品中文字幕一区二区| 91精品久久久久久蜜臀| 亚洲国产欧美另类丝袜| 欧美综合天天夜夜久久| 亚洲婷婷国产精品电影人久久| 国产又粗又猛又爽又黄91精品| 欧美一级黄色大片| 日本欧美大码aⅴ在线播放| 91黄色免费网站| 亚洲曰韩产成在线| 色88888久久久久久影院按摩| 亚洲欧美在线视频观看| 懂色av一区二区三区免费观看| 国产欧美一区二区三区在线看蜜臀| 狂野欧美性猛交blacked| 欧美va亚洲va| 国产美女一区二区| 久久视频一区二区| 国产精品一二三在| 中文av一区特黄| 99久久精品免费看| 亚洲黄色小说网站| 欧美男女性生活在线直播观看| 亚洲成人第一页| 欧美日韩国产高清一区二区三区| 亚洲国产日韩a在线播放| 欧美日本在线播放| 亚洲图片自拍偷拍| 日韩欧美亚洲国产精品字幕久久久| 狠狠色丁香久久婷婷综| 久久久久久久久久久电影| 成人激情免费视频| 亚洲免费av在线| 777久久久精品| 国产一区不卡视频| 综合自拍亚洲综合图不卡区| 欧美亚洲丝袜传媒另类| 九色综合国产一区二区三区| 欧美经典三级视频一区二区三区| 99综合影院在线| 亚洲国产精品影院| xfplay精品久久| 97se狠狠狠综合亚洲狠狠| 五月天丁香久久| 久久精品视频免费| 欧美亚洲尤物久久| 国产乱妇无码大片在线观看| 亚洲激情一二三区| 精品久久久久一区二区国产| 国产不卡视频在线播放| 亚洲电影中文字幕在线观看| 久久久久久久综合狠狠综合| 在线欧美日韩国产| 狠狠网亚洲精品| 午夜免费欧美电影| 中文字幕高清一区| 日韩网站在线看片你懂的| 91在线视频播放地址| 精品一区二区三区免费观看| 日韩一区有码在线| 久久男人中文字幕资源站| 91美女精品福利| 国产成人精品网址| 久久99国产精品麻豆| 亚洲精品videosex极品| 国产亚洲欧美在线| 91精品中文字幕一区二区三区| 成人免费观看视频| 久久精品国产99| 图片区小说区国产精品视频| 日韩美女精品在线| 中文字幕av在线一区二区三区| 日韩欧美电影在线| 欧美日本在线视频| 欧美影院一区二区| 一本色道久久综合亚洲aⅴ蜜桃| 国产99久久久久久免费看农村| 美日韩黄色大片| 日韩在线a电影| 亚洲第一二三四区| 一区二区日韩av| 亚洲自拍偷拍欧美| 一区二区欧美视频| 亚洲日穴在线视频| 亚洲美女视频在线观看| 91精品国产一区二区三区香蕉| 91久久精品一区二区三| 色综合天天综合网天天看片| 国产激情一区二区三区| 狠狠色丁香久久婷婷综合_中| 另类的小说在线视频另类成人小视频在线 | 亚洲人成网站影音先锋播放| 国产精品每日更新| 2021中文字幕一区亚洲| 日韩女同互慰一区二区| 69堂精品视频| 日韩一区二区三区在线观看 | 波多野结衣中文字幕一区二区三区| 国产真实精品久久二三区| 国产精品影视在线| 岛国精品在线观看| 99国产精品久久久| 91久久国产综合久久| 欧美美女激情18p| 日韩视频一区二区三区在线播放| 精品三级在线看| 欧美国产精品一区二区| 自拍偷在线精品自拍偷无码专区| 亚洲免费观看高清完整版在线观看 | 在线视频欧美精品| 欧美日韩精品久久久| 精品少妇一区二区三区在线播放| 欧美大片国产精品| 欧美国产乱子伦| 午夜在线电影亚洲一区| 韩国精品在线观看| 99精品热视频| 欧美一级二级在线观看| 国产精品麻豆99久久久久久| 亚洲夂夂婷婷色拍ww47| 卡一卡二国产精品| 色婷婷综合激情| 欧美电视剧在线看免费| 亚洲女与黑人做爰| 久久成人免费电影| 色婷婷亚洲婷婷| 久久久久久日产精品| 亚洲伊人色欲综合网| 国产一区二三区| 欧美少妇性性性| 国产精品高潮呻吟| 韩国成人精品a∨在线观看| 97se亚洲国产综合在线| 精品剧情在线观看| 香蕉av福利精品导航 |