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

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

?? pagerank.cs

?? 類似google的源代碼
?? CS
字號:
?using System;

namespace PRCalculate
{
    /// <summary>
    /// Google PageRank的Checksum算法。
    /// 
    /// 
    /// 
    /// </summary>
    class CheckSum
    {
        public CheckSum()
        {
            //
            // TODO: 在此處添加構造函數邏輯
            //
        }

        uint GOOGLE_MAGIC = 0xE6359A60;

        private uint zeroFill(uint a, int b)
        {
            checked
            {
                uint z = 0x80000000;
                if (Convert.ToBoolean(z & a))
                {
                    a = (a >> 1);
                    a &= (~z);
                    a |= 0x40000000;
                    a = (a >> (b - 1));
                }
                else
                {
                    a = (a >> b);
                }
            }
            return a;
        }

        private uint[] mix(uint a, uint b, uint c)
        {
            a -= b; a -= c; a ^= (uint)(zeroFill(c, 13));
            b -= c; b -= a; b ^= (uint)(a << 8);
            c -= a; c -= b; c ^= (uint)(zeroFill(b, 13));
            a -= b; a -= c; a ^= (uint)(zeroFill(c, 12));
            b -= c; b -= a; b ^= (uint)(a << 16);
            c -= a; c -= b; c ^= (uint)(zeroFill(b, 5));
            a -= b; a -= c; a ^= (uint)(zeroFill(c, 3));
            b -= c; b -= a; b ^= (uint)(a << 10);
            c -= a; c -= b; c ^= (uint)(zeroFill(b, 15));

            return new uint[3] { a, b, c };
        }

        private uint GoogleCH(uint[] url, uint length, uint init)
        {
            if (length == 0)
            {
                length = (uint)url.Length;
            }
            uint a, b;
            a = b = 0x9E3779B9;
            uint c = init;
            int k = 0;
            uint len = length;
            uint[] m_mix = new uint[3];
            while (len >= 12)
            {
                a += (uint)(url[k + 0] + (url[k + 1] << 8) + (url[k + 2] << 16) + (url[k + 3] << 24));
                b += (uint)(url[k + 4] + (url[k + 5] << 8) + (url[k + 6] << 16) + (url[k + 7] << 24));
                c += (uint)(url[k + 8] + (url[k + 9] << 8) + (url[k + 10] << 16) + (url[k + 11] << 24));
                m_mix = mix(a, b, c);
                a = m_mix[0]; b = m_mix[1]; c = m_mix[2];

                k += 12;
                len -= 12;
            }

            c += length;

            switch (len)              /* all the case statements fall through */
            {
                case 11:
                    {
                        c += (uint)(url[k + 10] << 24);
                        c += (uint)(url[k + 9] << 16);
                        c += (uint)(url[k + 8] << 8);
                        b += (uint)(url[k + 7] << 24);
                        b += (uint)(url[k + 6] << 16);
                        b += (uint)(url[k + 5] << 8);
                        b += (uint)(url[k + 4]);
                        a += (uint)(url[k + 3] << 24);
                        a += (uint)(url[k + 2] << 16);
                        a += (uint)(url[k + 1] << 8);
                        a += (uint)(url[k + 0]);
                        break;
                    }
                case 10:
                    {
                        c += (uint)(url[k + 9] << 16);
                        c += (uint)(url[k + 8] << 8);
                        b += (uint)(url[k + 7] << 24);
                        b += (uint)(url[k + 6] << 16);
                        b += (uint)(url[k + 5] << 8);
                        b += (uint)(url[k + 4]);
                        a += (uint)(url[k + 3] << 24);
                        a += (uint)(url[k + 2] << 16);
                        a += (uint)(url[k + 1] << 8);
                        a += (uint)(url[k + 0]);
                        break;
                    }
                case 9:
                    {
                        c += (uint)(url[k + 8] << 8);
                        b += (uint)(url[k + 7] << 24);
                        b += (uint)(url[k + 6] << 16);
                        b += (uint)(url[k + 5] << 8);
                        b += (uint)(url[k + 4]);
                        a += (uint)(url[k + 3] << 24);
                        a += (uint)(url[k + 2] << 16);
                        a += (uint)(url[k + 1] << 8);
                        a += (uint)(url[k + 0]);
                        break;
                    }
                /* the first byte of c is reserved for the length */
                case 8:
                    {
                        b += (uint)(url[k + 7] << 24);
                        b += (uint)(url[k + 6] << 16);
                        b += (uint)(url[k + 5] << 8);
                        b += (uint)(url[k + 4]);
                        a += (uint)(url[k + 3] << 24);
                        a += (uint)(url[k + 2] << 16);
                        a += (uint)(url[k + 1] << 8);
                        a += (uint)(url[k + 0]);
                        break;
                    }
                case 7:
                    {
                        b += (uint)(url[k + 6] << 16);
                        b += (uint)(url[k + 5] << 8);
                        b += (uint)(url[k + 4]);
                        a += (uint)(url[k + 3] << 24);
                        a += (uint)(url[k + 2] << 16);
                        a += (uint)(url[k + 1] << 8);
                        a += (uint)(url[k + 0]);
                        break;
                    }
                case 6:
                    {
                        b += (uint)(url[k + 5] << 8);
                        b += (uint)(url[k + 4]);
                        a += (uint)(url[k + 3] << 24);
                        a += (uint)(url[k + 2] << 16);
                        a += (uint)(url[k + 1] << 8);
                        a += (uint)(url[k + 0]);
                        break;
                    }
                case 5:
                    {
                        b += (uint)(url[k + 4]);
                        a += (uint)(url[k + 3] << 24);
                        a += (uint)(url[k + 2] << 16);
                        a += (uint)(url[k + 1] << 8);
                        a += (uint)(url[k + 0]);
                        break;
                    }
                case 4:
                    {
                        a += (uint)(url[k + 3] << 24);
                        a += (uint)(url[k + 2] << 16);
                        a += (uint)(url[k + 1] << 8);
                        a += (uint)(url[k + 0]);
                        break;
                    }
                case 3:
                    {
                        a += (uint)(url[k + 2] << 16);
                        a += (uint)(url[k + 1] << 8);
                        a += (uint)(url[k + 0]);
                        break;
                    }
                case 2:
                    {
                        a += (uint)(url[k + 1] << 8);
                        a += (uint)(url[k + 0]);
                        break;
                    }
                case 1:
                    {
                        a += (uint)(url[k + 0]);
                        break;
                    }
                /* case 0: nothing left to add */
            }
            m_mix = mix(a, b, c);
            /*-------------------------------------------- report the result */
            return m_mix[2];
        }

        private uint GoogleCH(string url, uint length)
        {
            uint[] m_urluint = new uint[url.Length];
            for (int i = 0; i < url.Length; i++)
            {
                m_urluint[i] = url[i];
            }
            return GoogleCH(m_urluint, length, GOOGLE_MAGIC);
        }

        private uint GoogleCH(string sURL)
        {
            return GoogleCH(sURL, 0);
        }
        private uint GoogleCH(uint[] url, uint length)
        {
            return GoogleCH(url, length, GOOGLE_MAGIC);
        }

        private uint[] c32to8bit(uint[] arr32)
        {
            uint[] arr8 = new uint[arr32.GetLength(0) * 4 + 3];

            for (int i = 0; i < arr32.GetLength(0); i++)
            {
                for (int bitOrder = i * 4; bitOrder <= i * 4 + 3; bitOrder++)
                {
                    arr8[bitOrder] = arr32[i] & 255;
                    arr32[i] = zeroFill(arr32[i], 8);
                }
            }
            return arr8;
        }

        //新算法,ToolBar 版本>>=2.0.114
        public string CalculateChecksum(string sURL)
        {
            uint ch = GoogleCH("info:" + sURL);

            ch = (((ch / 7) << 2) | (((uint)(ch % 13)) & 7));

            uint[] prbuf = new uint[20];
            prbuf[0] = ch;
            for (int i = 1; i < 20; i++)
            {
                prbuf[i] = prbuf[i - 1] - 9;
            }
            ch = GoogleCH(c32to8bit(prbuf), 80);

            return string.Format("6{0}", ch);
        }

        //老算法,ToolBar 版本<2.0.114
        public string CalculateChecksumOld(string sURL)
        {
            uint ch = GoogleCH("info:" + sURL);

            string CalculateChecksum = "6" + Convert.ToString((ch));
            return CalculateChecksum;
        }
    }
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
久久电影国产免费久久电影| 精品视频免费看| 欧美欧美欧美欧美首页| xfplay精品久久| 亚洲午夜在线观看视频在线| 高清不卡一二三区| 精品国产乱码久久久久久夜甘婷婷| 亚洲欧美日韩小说| 成人深夜在线观看| 精品国产免费视频| 麻豆国产91在线播放| 欧美日韩国产123区| 一区二区三区中文字幕精品精品| 国产成人av电影在线播放| 日韩欧美电影一区| 日韩国产在线一| 欧美三级午夜理伦三级中视频| 亚洲色图视频网| 成人午夜精品一区二区三区| 久久久www成人免费无遮挡大片| 青草av.久久免费一区| 欧美人牲a欧美精品| 亚洲成年人影院| 欧美日韩激情在线| 天天影视色香欲综合网老头| 欧美在线free| 一区二区国产视频| 在线观看av不卡| 亚洲乱码国产乱码精品精可以看| 9人人澡人人爽人人精品| 亚洲欧洲www| 色av综合在线| 亚洲永久精品大片| 欧美午夜电影一区| 亚洲h精品动漫在线观看| 欧美精品自拍偷拍| 日韩**一区毛片| 精品噜噜噜噜久久久久久久久试看| 久久国产福利国产秒拍| 国产午夜精品美女毛片视频| 国产成人av一区二区三区在线| 中文字幕精品一区二区三区精品| 粉嫩aⅴ一区二区三区四区| 中文字幕在线播放不卡一区| 91免费国产在线观看| 亚洲一区二区欧美| 91麻豆精品国产无毒不卡在线观看| 日本特黄久久久高潮| 日韩欧美久久久| 成人网在线播放| 亚洲成人免费视| 久久夜色精品国产噜噜av| 成人一区在线观看| 樱花影视一区二区| 欧美电视剧免费观看| 成人毛片视频在线观看| 一区二区国产视频| 久久影视一区二区| 91看片淫黄大片一级在线观看| 丝袜国产日韩另类美女| 国产亚洲精品中文字幕| 色婷婷久久综合| 美女久久久精品| 亚洲男女一区二区三区| 欧美一区日韩一区| av电影一区二区| 日本不卡视频在线| 国产精品不卡在线观看| 日韩一区二区在线观看视频 | 亚洲五月六月丁香激情| 91精品国产丝袜白色高跟鞋| 岛国av在线一区| 亚洲a一区二区| 国产精品美女久久久久aⅴ| 欧美疯狂做受xxxx富婆| 国产成人在线视频网址| 日韩av电影天堂| 亚洲免费av在线| 久久精品一区二区| 欧美福利一区二区| 91免费精品国自产拍在线不卡| 精品一区二区三区久久| 亚洲国产日韩一级| 亚洲免费观看高清完整版在线观看熊| 日韩免费福利电影在线观看| 欧美伊人久久久久久久久影院 | 蜜臀av一区二区在线免费观看| 国产精品午夜免费| 精品国产欧美一区二区| 欧美男男青年gay1069videost| jvid福利写真一区二区三区| 黑人精品欧美一区二区蜜桃| 激情综合网天天干| 午夜久久久久久久久久一区二区| 国产日韩欧美a| 欧美成人官网二区| 91精品久久久久久久久99蜜臂| 91在线小视频| 99精品一区二区三区| 粉嫩aⅴ一区二区三区四区五区| 麻豆精品视频在线观看| 五月天国产精品| 丝袜脚交一区二区| 午夜欧美2019年伦理| 亚洲电影视频在线| 亚洲综合在线视频| 亚洲伊人伊色伊影伊综合网| 亚洲色欲色欲www| 综合久久综合久久| 亚洲精品美腿丝袜| 亚洲黄色在线视频| 亚洲一区二区av电影| 亚洲一区二区影院| 亚洲chinese男男1069| 亚洲午夜久久久久久久久电影网| 一区二区三区蜜桃网| 亚洲一区二区四区蜜桃| 亚洲www啪成人一区二区麻豆| 亚洲国产精品久久人人爱蜜臀| 亚洲综合男人的天堂| 一区二区三区日韩在线观看| 亚洲午夜影视影院在线观看| 亚洲成av人**亚洲成av**| 亚欧色一区w666天堂| 日韩av不卡在线观看| 精品一区二区免费看| 国产精品99久久久久| yourporn久久国产精品| 91免费国产在线| 欧美精品免费视频| 久久先锋影音av鲁色资源| 欧美精品一区在线观看| 国产精品久久久久一区二区三区| 亚洲视频资源在线| 亚洲成av人片在线| 极品少妇xxxx精品少妇偷拍| 丁香一区二区三区| 在线观看亚洲专区| 精品人在线二区三区| 欧美激情一区二区三区| 亚洲国产中文字幕| 国内精品视频666| 91视频一区二区| 7777精品伊人久久久大香线蕉完整版 | 久久9热精品视频| 丁香激情综合国产| 欧美在线观看一二区| 日韩欧美不卡一区| 亚洲天堂久久久久久久| 日韩福利电影在线| 不卡一区二区三区四区| 欧美日韩日日夜夜| 欧美高清在线精品一区| 亚洲成av人片在www色猫咪| 国产乱人伦偷精品视频不卡| 91亚洲精品一区二区乱码| 91精品国产综合久久婷婷香蕉| 国产精品久久久99| 日本亚洲电影天堂| 99精品桃花视频在线观看| 在线成人av影院| 中文字幕在线不卡国产视频| 免费成人在线播放| 91久久精品网| 欧美激情在线看| 精品亚洲欧美一区| 欧美日韩电影一区| 亚洲欧美日韩国产另类专区| 国产一区二区三区久久久| 欧美日韩在线三级| 中文字幕一区二区三区在线播放| 美女www一区二区| 欧美日韩一级片在线观看| 亚洲色图在线播放| 成人性生交大片免费看视频在线 | 日本高清不卡在线观看| 国产午夜精品久久久久久久| 日产欧产美韩系列久久99| 91小视频在线观看| 国产精品美女一区二区三区| 精品综合免费视频观看| 91精品一区二区三区久久久久久 | 欧美亚洲丝袜传媒另类| 亚洲欧美在线高清| www.综合网.com| 亚洲国产精品精华液ab| 韩国在线一区二区| 精品久久国产老人久久综合| 日韩综合在线视频| 制服丝袜亚洲精品中文字幕| 亚洲一区二区欧美日韩| 欧美性猛交xxxxxx富婆| 亚洲一区二区视频| 欧美在线视频不卡| 亚洲国产va精品久久久不卡综合| 91福利国产精品| 亚洲成人动漫av| 欧美一级高清大全免费观看| 奇米影视一区二区三区| 91精品国产色综合久久久蜜香臀|