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

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

?? compress.c

?? dc++(一個曾經大量使用的p2p)的源代碼,dc++,開源的p2p源代碼
?? C
?? 第 1 頁 / 共 2 頁
字號:
/*-------------------------------------------------------------*//*--- Compression machinery (not incl block sorting)        ---*//*---                                            compress.c ---*//*-------------------------------------------------------------*//*--  This file is a part of bzip2 and/or libbzip2, a program and  library for lossless, block-sorting data compression.  Copyright (C) 1996-2002 Julian R Seward.  All rights reserved.  Redistribution and use in source and binary forms, with or without  modification, are permitted provided that the following conditions  are met:  1. Redistributions of source code must retain the above copyright     notice, this list of conditions and the following disclaimer.  2. The origin of this software must not be misrepresented; you must      not claim that you wrote the original software.  If you use this      software in a product, an acknowledgment in the product      documentation would be appreciated but is not required.  3. Altered source versions must be plainly marked as such, and must     not be misrepresented as being the original software.  4. The name of the author may not be used to endorse or promote      products derived from this software without specific prior written      permission.  THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS  OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED  WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE  ARE DISCLAIMED.  IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY  DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL  DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE  GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS  INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,  WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING  NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS  SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.  Julian Seward, Cambridge, UK.  jseward@acm.org  bzip2/libbzip2 version 1.0 of 21 March 2000  This program is based on (at least) the work of:     Mike Burrows     David Wheeler     Peter Fenwick     Alistair Moffat     Radford Neal     Ian H. Witten     Robert Sedgewick     Jon L. Bentley  For more information on these sources, see the manual.--*//*--   CHANGES   ~~~~~~~   0.9.0 -- original version.   0.9.0a/b -- no changes in this file.   0.9.0c      * changed setting of nGroups in sendMTFValues() so as to         do a bit better on small files--*/#include "bzlib_private.h"/*---------------------------------------------------*//*--- Bit stream I/O                              ---*//*---------------------------------------------------*//*---------------------------------------------------*/void BZ2_bsInitWrite ( EState* s ){   s->bsLive = 0;   s->bsBuff = 0;}/*---------------------------------------------------*/staticvoid bsFinishWrite ( EState* s ){   while (s->bsLive > 0) {      s->zbits[s->numZ] = (UChar)(s->bsBuff >> 24);      s->numZ++;      s->bsBuff <<= 8;      s->bsLive -= 8;   }}/*---------------------------------------------------*/#define bsNEEDW(nz)                           \{                                             \   while (s->bsLive >= 8) {                   \      s->zbits[s->numZ]                       \         = (UChar)(s->bsBuff >> 24);          \      s->numZ++;                              \      s->bsBuff <<= 8;                        \      s->bsLive -= 8;                         \   }                                          \}/*---------------------------------------------------*/static__inline__void bsW ( EState* s, Int32 n, UInt32 v ){   bsNEEDW ( n );   s->bsBuff |= (v << (32 - s->bsLive - n));   s->bsLive += n;}/*---------------------------------------------------*/staticvoid bsPutUInt32 ( EState* s, UInt32 u ){   bsW ( s, 8, (u >> 24) & 0xffL );   bsW ( s, 8, (u >> 16) & 0xffL );   bsW ( s, 8, (u >>  8) & 0xffL );   bsW ( s, 8,  u        & 0xffL );}/*---------------------------------------------------*/staticvoid bsPutUChar ( EState* s, UChar c ){   bsW( s, 8, (UInt32)c );}/*---------------------------------------------------*//*--- The back end proper                         ---*//*---------------------------------------------------*//*---------------------------------------------------*/staticvoid makeMaps_e ( EState* s ){   Int32 i;   s->nInUse = 0;   for (i = 0; i < 256; i++)      if (s->inUse[i]) {         s->unseqToSeq[i] = s->nInUse;         s->nInUse++;      }}/*---------------------------------------------------*/staticvoid generateMTFValues ( EState* s ){   UChar   yy[256];   Int32   i, j;   Int32   zPend;   Int32   wr;   Int32   EOB;   /*       After sorting (eg, here),         s->arr1 [ 0 .. s->nblock-1 ] holds sorted order,         and         ((UChar*)s->arr2) [ 0 .. s->nblock-1 ]          holds the original block data.      The first thing to do is generate the MTF values,      and put them in         ((UInt16*)s->arr1) [ 0 .. s->nblock-1 ].      Because there are strictly fewer or equal MTF values      than block values, ptr values in this area are overwritten      with MTF values only when they are no longer needed.      The final compressed bitstream is generated into the      area starting at         (UChar*) (&((UChar*)s->arr2)[s->nblock])      These storage aliases are set up in bzCompressInit(),      except for the last one, which is arranged in       compressBlock().   */   UInt32* ptr   = s->ptr;   UChar* block  = s->block;   UInt16* mtfv  = s->mtfv;   makeMaps_e ( s );   EOB = s->nInUse+1;   for (i = 0; i <= EOB; i++) s->mtfFreq[i] = 0;   wr = 0;   zPend = 0;   for (i = 0; i < s->nInUse; i++) yy[i] = (UChar) i;   for (i = 0; i < s->nblock; i++) {      UChar ll_i;      AssertD ( wr <= i, "generateMTFValues(1)" );      j = ptr[i]-1; if (j < 0) j += s->nblock;      ll_i = s->unseqToSeq[block[j]];      AssertD ( ll_i < s->nInUse, "generateMTFValues(2a)" );      if (yy[0] == ll_i) {          zPend++;      } else {         if (zPend > 0) {            zPend--;            while (True) {               if (zPend & 1) {                  mtfv[wr] = BZ_RUNB; wr++;                   s->mtfFreq[BZ_RUNB]++;                } else {                  mtfv[wr] = BZ_RUNA; wr++;                   s->mtfFreq[BZ_RUNA]++;                }               if (zPend < 2) break;               zPend = (zPend - 2) / 2;            };            zPend = 0;         }         {            register UChar  rtmp;            register UChar* ryy_j;            register UChar  rll_i;            rtmp  = yy[1];            yy[1] = yy[0];            ryy_j = &(yy[1]);            rll_i = ll_i;            while ( rll_i != rtmp ) {               register UChar rtmp2;               ryy_j++;               rtmp2  = rtmp;               rtmp   = *ryy_j;               *ryy_j = rtmp2;            };            yy[0] = rtmp;            j = ryy_j - &(yy[0]);            mtfv[wr] = j+1; wr++; s->mtfFreq[j+1]++;         }      }   }   if (zPend > 0) {      zPend--;      while (True) {         if (zPend & 1) {            mtfv[wr] = BZ_RUNB; wr++;             s->mtfFreq[BZ_RUNB]++;          } else {            mtfv[wr] = BZ_RUNA; wr++;             s->mtfFreq[BZ_RUNA]++;          }         if (zPend < 2) break;         zPend = (zPend - 2) / 2;      };      zPend = 0;   }   mtfv[wr] = EOB; wr++; s->mtfFreq[EOB]++;   s->nMTF = wr;}/*---------------------------------------------------*/#define BZ_LESSER_ICOST  0#define BZ_GREATER_ICOST 15staticvoid sendMTFValues ( EState* s ){   Int32 v, t, i, j, gs, ge, totc, bt, bc, iter;   Int32 nSelectors, alphaSize, minLen, maxLen, selCtr;   Int32 nGroups, nBytes;   /*--   UChar  len [BZ_N_GROUPS][BZ_MAX_ALPHA_SIZE];   is a global since the decoder also needs it.   Int32  code[BZ_N_GROUPS][BZ_MAX_ALPHA_SIZE];   Int32  rfreq[BZ_N_GROUPS][BZ_MAX_ALPHA_SIZE];   are also globals only used in this proc.   Made global to keep stack frame size small.   --*/   UInt16 cost[BZ_N_GROUPS];   Int32  fave[BZ_N_GROUPS];   UInt16* mtfv = s->mtfv;   if (s->verbosity >= 3)      VPrintf3( "      %d in block, %d after MTF & 1-2 coding, "                "%d+2 syms in use\n",                 s->nblock, s->nMTF, s->nInUse );   alphaSize = s->nInUse+2;   for (t = 0; t < BZ_N_GROUPS; t++)      for (v = 0; v < alphaSize; v++)         s->len[t][v] = BZ_GREATER_ICOST;   /*--- Decide how many coding tables to use ---*/   AssertH ( s->nMTF > 0, 3001 );   if (s->nMTF < 200)  nGroups = 2; else   if (s->nMTF < 600)  nGroups = 3; else   if (s->nMTF < 1200) nGroups = 4; else   if (s->nMTF < 2400) nGroups = 5; else                       nGroups = 6;   /*--- Generate an initial set of coding tables ---*/   {       Int32 nPart, remF, tFreq, aFreq;      nPart = nGroups;      remF  = s->nMTF;      gs = 0;      while (nPart > 0) {         tFreq = remF / nPart;         ge = gs-1;         aFreq = 0;         while (aFreq < tFreq && ge < alphaSize-1) {            ge++;            aFreq += s->mtfFreq[ge];         }         if (ge > gs              && nPart != nGroups && nPart != 1              && ((nGroups-nPart) % 2 == 1)) {            aFreq -= s->mtfFreq[ge];            ge--;         }         if (s->verbosity >= 3)            VPrintf5( "      initial group %d, [%d .. %d], "                      "has %d syms (%4.1f%%)\n",                      nPart, gs, ge, aFreq,                       (100.0 * (float)aFreq) / (float)(s->nMTF) );          for (v = 0; v < alphaSize; v++)            if (v >= gs && v <= ge)                s->len[nPart-1][v] = BZ_LESSER_ICOST; else               s->len[nPart-1][v] = BZ_GREATER_ICOST;          nPart--;         gs = ge+1;

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
蜜桃视频第一区免费观看| 欧美在线观看你懂的| 国产精品888| 不卡av在线免费观看| 色偷偷久久一区二区三区| 日韩亚洲国产中文字幕欧美| 国产日韩欧美精品一区| 亚洲欧美日韩在线不卡| 美女在线一区二区| 波多野结衣亚洲一区| 欧美日韩一本到| 久久久精品国产99久久精品芒果 | 视频在线在亚洲| 国产乱淫av一区二区三区| 色综合天天狠狠| 91精品国产品国语在线不卡| 久久久久综合网| 亚洲精品第一国产综合野| 美女视频黄久久| av中文字幕一区| 91精品国产高清一区二区三区蜜臀 | 中文字幕不卡一区| 日本最新不卡在线| jlzzjlzz亚洲日本少妇| 欧美一区二区三区男人的天堂| 国产精品大尺度| 久久成人免费日本黄色| 色综合久久综合网97色综合| 精品少妇一区二区三区| 亚洲一区二区三区美女| 国产suv精品一区二区6| 日韩免费高清av| 亚洲精品免费视频| 国产二区国产一区在线观看| 欧美精三区欧美精三区| 亚洲欧洲精品天堂一级| 久久av中文字幕片| 欧美丰满少妇xxxxx高潮对白| 国产精品国产自产拍在线| 久久精品国产**网站演员| 色婷婷久久99综合精品jk白丝| 国产午夜精品理论片a级大结局 | 欧美日韩一区 二区 三区 久久精品| 久久久久九九视频| 免费观看一级特黄欧美大片| 在线观看不卡一区| 国产日韩亚洲欧美综合| 久久国产夜色精品鲁鲁99| 欧美日韩视频一区二区| 亚洲欧美色一区| jiyouzz国产精品久久| 久久精品这里都是精品| 久久99精品国产麻豆婷婷| 欧美精品v日韩精品v韩国精品v| 有坂深雪av一区二区精品| 不卡一区在线观看| 国产欧美日韩麻豆91| 国产一区二区三区视频在线播放| 制服丝袜国产精品| 婷婷综合五月天| 在线观看91精品国产入口| 日韩毛片高清在线播放| a美女胸又www黄视频久久| 国产精品美女www爽爽爽| 国产69精品久久久久毛片| 精品久久一区二区三区| 蜜臀精品一区二区三区在线观看 | 一个色在线综合| 91麻豆自制传媒国产之光| 国产精品久久毛片av大全日韩| 成人高清视频在线观看| 欧美国产一区二区| 成人午夜av在线| 欧美国产一区二区| 99在线热播精品免费| 亚洲欧洲日韩av| 色哟哟欧美精品| 亚洲国产日日夜夜| 欧美片在线播放| 日韩和欧美一区二区| 欧美一区二区免费视频| 蜜桃av噜噜一区| 2017欧美狠狠色| 国产成人激情av| 国产精品视频看| 一本一本大道香蕉久在线精品| 悠悠色在线精品| 欧美丰满少妇xxxxx高潮对白| 男女男精品网站| 国产日韩精品一区二区三区| 成人aaaa免费全部观看| 亚洲色图另类专区| 欧美日韩一区二区三区视频| 美女视频网站黄色亚洲| 国产色91在线| 99精品国产99久久久久久白柏| 亚洲免费观看高清完整版在线观看熊| 欧美视频你懂的| 精品一区二区三区视频| 国产肉丝袜一区二区| 99re66热这里只有精品3直播| 亚洲一区二区视频| 日韩欧美一级二级| 懂色av一区二区三区免费看| 亚洲美女少妇撒尿| 欧美一区二区三区思思人| 国产精品99久| 亚洲综合色网站| 日韩视频在线观看一区二区| 国产成人综合在线观看| 亚洲久本草在线中文字幕| 欧美高清www午色夜在线视频| 国产精品影视天天线| 亚洲精品免费在线| 欧美电视剧免费观看| 91社区在线播放| 美腿丝袜在线亚洲一区| 国产精品狼人久久影院观看方式| 欧美日韩一卡二卡| 国产剧情av麻豆香蕉精品| 玉足女爽爽91| 久久一区二区三区四区| 色久综合一二码| 激情深爱一区二区| 亚洲美女一区二区三区| 欧美成人精精品一区二区频| 成人午夜精品一区二区三区| 日韩电影一区二区三区| 亚洲欧洲国产专区| 欧美xxxx在线观看| 欧美体内she精高潮| 国产成人av电影在线播放| 午夜久久久久久久久| 国产精品乱人伦一区二区| 欧美一级高清片在线观看| av不卡一区二区三区| 国内久久精品视频| 亚洲电影在线播放| 国产精品乱人伦| 亚洲精品在线观看网站| 欧美日韩久久久一区| a4yy欧美一区二区三区| 国产美女精品一区二区三区| 亚洲.国产.中文慕字在线| 国产精品动漫网站| 精品久久久久一区| 欧美日韩国产乱码电影| 91视频你懂的| 成人午夜视频在线| 久久精品免费观看| 亚洲午夜电影网| 中文字幕一区二区三中文字幕| 久久综合久久综合九色| 欧美剧在线免费观看网站 | 一区二区三区四区在线播放| 国产日韩欧美一区二区三区综合| 9191成人精品久久| 欧美三级在线看| 91在线高清观看| 成人激情动漫在线观看| 国产在线精品一区二区三区不卡 | 久久精品99久久久| 婷婷一区二区三区| 中文字幕佐山爱一区二区免费| 日本一区二区电影| 国产亚洲精品资源在线26u| 日韩欧美国产一二三区| 欧美日韩黄色影视| 欧美亚洲免费在线一区| 91啪亚洲精品| 91丨porny丨户外露出| 福利一区福利二区| 国产精品1区2区| 国产酒店精品激情| 国产美女视频一区| 国产99久久久国产精品潘金网站| 狠狠色综合播放一区二区| 精品午夜一区二区三区在线观看| 免费人成精品欧美精品| 水蜜桃久久夜色精品一区的特点 | 国产精品久久久久久一区二区三区| 久久久久久日产精品| 久久综合99re88久久爱| 久久久综合网站| 久久免费偷拍视频| 欧美激情艳妇裸体舞| 国产精品素人一区二区| 国产精品初高中害羞小美女文| 国产精品欧美综合在线| 国产精品福利一区二区三区| 国产精品久久久久久久久免费樱桃| 中文字幕av一区二区三区免费看| 中文字幕欧美日韩一区| 中文字幕一区二区5566日韩| 中文字幕一区二区三区乱码在线| 综合激情成人伊人| 亚洲激情校园春色| 亚洲成av人在线观看| 男男视频亚洲欧美| 国产伦理精品不卡|