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

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

?? adler32.c

?? ZIP壓縮算法源代碼,可以直接加入C++Project中編譯調用
?? C
字號:
/* adler32.c -- compute the Adler-32 checksum of a data stream
 * Copyright (C) 1995-2004 Mark Adler
 * For conditions of distribution and use, see copyright notice in zlib.h
 */

/* @(#) $Id$ */

#define ZLIB_INTERNAL
#include "zlib.h"

#define BASE 65521UL    /* largest prime smaller than 65536 */
#define NMAX 5552
/* NMAX is the largest n such that 255n(n+1)/2 + (n+1)(BASE-1) <= 2^32-1 */

#define DO1(buf,i)  {adler += (buf)[i]; sum2 += adler;}
#define DO2(buf,i)  DO1(buf,i); DO1(buf,i+1);
#define DO4(buf,i)  DO2(buf,i); DO2(buf,i+2);
#define DO8(buf,i)  DO4(buf,i); DO4(buf,i+4);
#define DO16(buf)   DO8(buf,0); DO8(buf,8);

/* use NO_DIVIDE if your processor does not do division in hardware */
#ifdef NO_DIVIDE
#  define MOD(a) \
    do { \
        if (a >= (BASE << 16)) a -= (BASE << 16); \
        if (a >= (BASE << 15)) a -= (BASE << 15); \
        if (a >= (BASE << 14)) a -= (BASE << 14); \
        if (a >= (BASE << 13)) a -= (BASE << 13); \
        if (a >= (BASE << 12)) a -= (BASE << 12); \
        if (a >= (BASE << 11)) a -= (BASE << 11); \
        if (a >= (BASE << 10)) a -= (BASE << 10); \
        if (a >= (BASE << 9)) a -= (BASE << 9); \
        if (a >= (BASE << 8)) a -= (BASE << 8); \
        if (a >= (BASE << 7)) a -= (BASE << 7); \
        if (a >= (BASE << 6)) a -= (BASE << 6); \
        if (a >= (BASE << 5)) a -= (BASE << 5); \
        if (a >= (BASE << 4)) a -= (BASE << 4); \
        if (a >= (BASE << 3)) a -= (BASE << 3); \
        if (a >= (BASE << 2)) a -= (BASE << 2); \
        if (a >= (BASE << 1)) a -= (BASE << 1); \
        if (a >= BASE) a -= BASE; \
    } while (0)
#  define MOD4(a) \
    do { \
        if (a >= (BASE << 4)) a -= (BASE << 4); \
        if (a >= (BASE << 3)) a -= (BASE << 3); \
        if (a >= (BASE << 2)) a -= (BASE << 2); \
        if (a >= (BASE << 1)) a -= (BASE << 1); \
        if (a >= BASE) a -= BASE; \
    } while (0)
#else
#  define MOD(a) a %= BASE
#  define MOD4(a) a %= BASE
#endif

/* ========================================================================= */
uLong ZEXPORT adler32(adler, buf, len)
    uLong adler;
    const Bytef *buf;
    uInt len;
{
    unsigned long sum2;
    unsigned n;

    /* split Adler-32 into component sums */
    sum2 = (adler >> 16) & 0xffff;
    adler &= 0xffff;

    /* in case user likes doing a byte at a time, keep it fast */
    if (len == 1) {
        adler += buf[0];
        if (adler >= BASE)
            adler -= BASE;
        sum2 += adler;
        if (sum2 >= BASE)
            sum2 -= BASE;
        return adler | (sum2 << 16);
    }

    /* initial Adler-32 value (deferred check for len == 1 speed) */
    if (buf == Z_NULL)
        return 1L;

    /* in case short lengths are provided, keep it somewhat fast */
    if (len < 16) {
        while (len--) {
            adler += *buf++;
            sum2 += adler;
        }
        if (adler >= BASE)
            adler -= BASE;
        MOD4(sum2);             /* only added so many BASE's */
        return adler | (sum2 << 16);
    }

    /* do length NMAX blocks -- requires just one modulo operation */
    while (len >= NMAX) {
        len -= NMAX;
        n = NMAX / 16;          /* NMAX is divisible by 16 */
        do {
            DO16(buf);          /* 16 sums unrolled */
            buf += 16;
        } while (--n);
        MOD(adler);
        MOD(sum2);
    }

    /* do remaining bytes (less than NMAX, still just one modulo) */
    if (len) {                  /* avoid modulos if none remaining */
        while (len >= 16) {
            len -= 16;
            DO16(buf);
            buf += 16;
        }
        while (len--) {
            adler += *buf++;
            sum2 += adler;
        }
        MOD(adler);
        MOD(sum2);
    }

    /* return recombined sums */
    return adler | (sum2 << 16);
}

/* ========================================================================= */
uLong ZEXPORT adler32_combine(adler1, adler2, len2)
    uLong adler1;
    uLong adler2;
    z_off_t len2;
{
    unsigned long sum1;
    unsigned long sum2;
    unsigned rem;

    /* the derivation of this formula is left as an exercise for the reader */
    rem = (unsigned)(len2 % BASE);
    sum1 = adler1 & 0xffff;
    sum2 = rem * sum1;
    MOD(sum2);
    sum1 += (adler2 & 0xffff) + BASE - 1;
    sum2 += ((adler1 >> 16) & 0xffff) + ((adler2 >> 16) & 0xffff) + BASE - rem;
    if (sum1 > BASE) sum1 -= BASE;
    if (sum1 > BASE) sum1 -= BASE;
    if (sum2 > (BASE << 1)) sum2 -= (BASE << 1);
    if (sum2 > BASE) sum2 -= BASE;
    return sum1 | (sum2 << 16);
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
99久久精品国产麻豆演员表| 久久久五月婷婷| 亚洲精品菠萝久久久久久久| 99久久99久久精品免费看蜜桃| 日韩理论片网站| 日本精品一区二区三区四区的功能| 亚洲精品日韩一| 欧美日韩一区二区三区在线看| 免费成人在线观看视频| 久久精品亚洲一区二区三区浴池| 成人激情午夜影院| 亚洲欧美激情一区二区| 欧美久久久久久久久| 奇米色一区二区| 久久精品免视看| 欧美在线一区二区| 久久精品噜噜噜成人av农村| 中文字幕精品在线不卡| 欧美在线一二三四区| 日本伊人精品一区二区三区观看方式| 2024国产精品视频| 色综合久久66| 精品午夜久久福利影院| 亚洲欧美怡红院| 欧美一区二区免费观在线| 不卡在线视频中文字幕| 欧美色综合影院| 一区二区三区在线观看欧美| 极品美女销魂一区二区三区| 884aa四虎影成人精品一区| 精品一区二区三区在线播放视频| 国产精品电影一区二区三区| 在线电影一区二区三区| av在线不卡免费看| 免费日本视频一区| 亚洲免费观看在线观看| 久久在线观看免费| 欧美男人的天堂一二区| 成人av资源站| 久久99精品久久久久久动态图| 最新高清无码专区| 精品理论电影在线| 欧美日韩久久一区二区| jlzzjlzz欧美大全| 国产麻豆日韩欧美久久| 五月天一区二区| 亚洲免费电影在线| 国产欧美一区二区三区网站| 日韩免费观看高清完整版 | 一区二区三区精品在线观看| 日韩女优av电影在线观看| 欧美影院精品一区| 99精品热视频| kk眼镜猥琐国模调教系列一区二区 | 狠狠色综合日日| 图片区小说区国产精品视频| 一卡二卡三卡日韩欧美| 成人免费一区二区三区在线观看| 久久影院午夜论| 2019国产精品| 久久综合久久久久88| 日韩你懂的在线观看| 7777精品久久久大香线蕉| 欧美亚洲动漫精品| 欧美在线三级电影| 欧美主播一区二区三区| eeuss鲁片一区二区三区在线观看 eeuss鲁片一区二区三区在线看 | 欧美午夜一区二区三区| 色先锋资源久久综合| 91亚洲精品一区二区乱码| 99在线热播精品免费| 成人污视频在线观看| 成人涩涩免费视频| 大白屁股一区二区视频| 成人黄色av网站在线| www.66久久| 欧美午夜精品一区二区三区| 欧洲亚洲国产日韩| 欧美日韩国产首页| 欧美一级片在线观看| 日韩一区和二区| 欧美成人bangbros| 国产亚洲欧洲一区高清在线观看| 国产婷婷色一区二区三区在线| 久久久蜜臀国产一区二区| 亚洲国产岛国毛片在线| 中文字幕在线观看不卡视频| 一区二区三区在线视频免费观看| 亚洲国产精品一区二区www在线| 午夜精品一区二区三区电影天堂 | 亚洲综合一二区| 午夜精品久久久久久不卡8050| 视频一区二区中文字幕| 久久精品国产一区二区| 国产麻豆视频一区| 色综合视频在线观看| 欧美日韩亚洲不卡| 欧美成人vr18sexvr| 国产精品久久久久7777按摩| 亚洲黄色av一区| 免费人成网站在线观看欧美高清| 国产精品亚洲一区二区三区在线| 99精品久久只有精品| 欧美伦理影视网| 国产欧美一区二区精品性| 亚洲天堂精品视频| 免费人成网站在线观看欧美高清| 国产 欧美在线| 欧美美女激情18p| 欧美精品一区二区三区视频| 国产精品久久久久影院| 亚洲一级二级在线| 狠狠色丁香婷婷综合| 91在线观看美女| 欧美高清一级片在线| 久久精品综合网| 亚洲国产乱码最新视频| 国产大陆精品国产| 精品视频免费在线| 国产精品女主播在线观看| 天堂在线亚洲视频| 不卡一区中文字幕| 欧美一卡二卡三卡| 亚洲欧美激情小说另类| 国产精品自拍三区| 欧美日韩一区国产| 中文字幕精品三区| 成人深夜视频在线观看| 欧美色成人综合| 国产精品进线69影院| 另类调教123区| 欧美日韩免费不卡视频一区二区三区| 国产日韩亚洲欧美综合| 日韩**一区毛片| 色婷婷国产精品久久包臀| 国产欧美一区二区三区在线看蜜臀 | 亚洲四区在线观看| 韩日欧美一区二区三区| 欧美日韩精品综合在线| 国产精品国产三级国产普通话三级| 久久精品国内一区二区三区| 欧美性猛交xxxxxxxx| 国产精品毛片无遮挡高清| 美日韩一级片在线观看| 欧美日韩一区成人| 一区二区三区国产豹纹内裤在线| 懂色av一区二区三区免费观看 | 奇米一区二区三区av| 欧美系列一区二区| 亚洲狠狠丁香婷婷综合久久久| 成人久久久精品乱码一区二区三区| 精品毛片乱码1区2区3区| 首页欧美精品中文字幕| 欧美亚洲一区二区在线| 亚洲女爱视频在线| 99久久精品国产导航| 国产精品网曝门| 成人丝袜高跟foot| 国产欧美精品在线观看| 国产精品69久久久久水密桃| 久久免费看少妇高潮| 国内精品伊人久久久久av一坑| 日韩精品一区二| 国产在线日韩欧美| 久久你懂得1024| 粉嫩久久99精品久久久久久夜| 国产性色一区二区| 成人v精品蜜桃久久一区| 国产欧美日韩不卡| 成人av网站在线| 自拍偷拍亚洲欧美日韩| 91在线视频官网| 一区二区三区鲁丝不卡| 欧美日韩大陆一区二区| 日韩精品亚洲一区| 精品免费99久久| 国产呦精品一区二区三区网站| 久久久www免费人成精品| 高清不卡一区二区| 亚洲精品国产a| 欧美日韩国产免费| 国产**成人网毛片九色 | 喷水一区二区三区| 精品国内二区三区| 粉嫩高潮美女一区二区三区| **网站欧美大片在线观看| 91黄色小视频| 美美哒免费高清在线观看视频一区二区| 欧美大胆人体bbbb| 成人一级片在线观看| 一区二区三区中文字幕精品精品| 欧美精品一二三四| 国产另类ts人妖一区二区| 自拍偷拍国产亚洲| 在线播放一区二区三区| 国产一区二区不卡在线| 亚洲精品亚洲人成人网在线播放| 欧美精品三级在线观看| 国产一区激情在线| 樱花草国产18久久久久|