• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>

            poj 2417 Discrete Logging

               這是個(gè)求離散對(duì)數(shù)的問(wèn)題。以前學(xué)密碼學(xué)基礎(chǔ)的時(shí)候也接觸過(guò),但是沒(méi)想到acm里面還會(huì)有這樣的習(xí)題。
               問(wèn)題的意思是給定素?cái)?shù)P,給出方程a^x = b % p,注意有模的方程等式2邊都是取模數(shù)的意思。解這樣的方程有一個(gè)固定的算法,
            叫做baby-step算法。但是,注意限定條件是p必須是素?cái)?shù)。
               下面的圖描述了這個(gè)算法:


               意思很清楚,就是假設(shè)x = i * m + j,那么方程可以轉(zhuǎn)化為b*(a^-m)^i  = a^j % p。先計(jì)算出右邊的值,存儲(chǔ)在一張表里面,
            然后從小到大枚舉左邊的i(0<=i<m),率先滿足等式的就是最小的解x。
               poj上面這個(gè)題用map存儲(chǔ)(a^j,j)對(duì)的時(shí)候會(huì)超時(shí),改成hash表存儲(chǔ)才能過(guò),額,畢竟理論復(fù)雜度不是一個(gè)數(shù)量級(jí)的。我的hash表是
            開(kāi)了2個(gè)數(shù)組,一個(gè)鍵,一個(gè)值,用來(lái)相互驗(yàn)證,槽沖突的話,一直往后找位置。感覺(jué)這樣的做法沒(méi)有鏈?zhǔn)絟ash復(fù)雜度平均的樣子。
               代碼如下:
            #include <stdio.h>
            #include <math.h>
            #include <algorithm>
            using namespace std;

            #define MAX (1000000)
            long long nData[MAX];
            long long nKey[MAX];
            long long egcd(long long a, long long b, long long& x, long long& y)
            {
                if (b == 0)
                {
                    x = 1;
                    y = 0;
                    return a;
                }
                long long ret = egcd(b, a % b, x, y);
                long long t = x;
                x = y;
                y = t - (a / b) * y;
                return ret;
            }

            long long GetPos(long long key)
            {
                 return (key ^ 0xA5A5A5A5) % MAX;
            }

            void Add(long long key, long long data)
            {
                long long nPos = GetPos(key);
                while (nData[nPos] != -1)
                {
                    nPos = (nPos + 1) % MAX;
                }
                nData[nPos] = data;
                nKey[nPos] = key;
            }

            int Query(int key)
            {
                int nPos = GetPos(key);
                
                while (nData[nPos] != -1)
                {
                    if (nKey[nPos] == key)
                    {
                        return nData[nPos];
                    }
                    nPos = (nPos + 1) % MAX;
                }
                return -1;
            }

            long long BabyStep(long long nA, long long nB, long long nP)
            {
                long long nM = ceil(sqrt((double)(nP - 1)));
                long long x, y;
                egcd(nP, nA, x, y);//y是nA%p的乘法逆
                y = (y + nP) % nP;
                long long nTemp = 1;
                long long c = 1;//c是nA的—m次
                memset(nData, -1, sizeof(nData));
                memset(nKey, -1, sizeof(nKey));
                for (long long j = 0; j < nM; ++j)
                {
                    Add(nTemp, j);
                    nTemp = (nTemp * nA) % nP;
                    c = (c * y) % nP;
                }
                
                long long r = nB;
                for (int i = 0; i < nM; ++i)
                {
                    long long j = Query(r);
                    if (j != -1)
                    {
                        return i * nM + j;
                    }
                    r = (r * c) % nP;
                }
                return -1;
            }

            int main()
            {
                long long nP, nB, nN;
                
                while (scanf("%I64d%I64d%I64d", &nP, &nB, &nN) == 3)
                {
                    long long nAns = BabyStep(nB, nN, nP);
                    if (nAns == -1)printf("no solution\n");
                    else printf("%I64d\n", nAns);
                }
                
                return 0;
            }

            posted on 2012-07-29 19:38 yx 閱讀(1168) 評(píng)論(0)  編輯 收藏 引用 所屬分類: 數(shù)論

            <2013年6月>
            2627282930311
            2345678
            9101112131415
            16171819202122
            23242526272829
            30123456

            導(dǎo)航

            統(tǒng)計(jì)

            公告

            常用鏈接

            留言簿(3)

            隨筆分類

            隨筆檔案

            me

            好友

            同學(xué)

            網(wǎng)友

            搜索

            最新評(píng)論

            閱讀排行榜

            評(píng)論排行榜

            久久久久99这里有精品10| 久久综合精品国产一区二区三区| 久久精品成人| 色婷婷久久久SWAG精品| 久久一区二区三区99| 国产真实乱对白精彩久久| 久久综合色区| 中文精品久久久久人妻| 久久亚洲AV成人无码国产| 久久99国产乱子伦精品免费| 久久婷婷综合中文字幕| 国产香蕉97碰碰久久人人| 久久精品国产一区二区| 久久无码一区二区三区少妇| 欧美久久久久久午夜精品| 亚洲国产成人久久综合碰| 久久久久久精品成人免费图片| 久久久久久亚洲Av无码精品专口| 99久久夜色精品国产网站| 亚洲综合精品香蕉久久网| 日韩精品国产自在久久现线拍| 51久久夜色精品国产| 国内精品九九久久久精品| 青青青青久久精品国产h| 久久99精品免费一区二区| 国产精品久久久久久久app| 亚洲午夜精品久久久久久人妖| 国产ww久久久久久久久久| 久久精品国产清自在天天线| 久久亚洲日韩精品一区二区三区| 国产精品一区二区久久不卡 | 无码国内精品久久综合88 | 囯产极品美女高潮无套久久久| 蜜臀av性久久久久蜜臀aⅴ麻豆| 四虎国产精品免费久久久 | 欧美精品九九99久久在观看| 久久久久人妻一区二区三区vr| 91亚洲国产成人久久精品| 国产69精品久久久久9999APGF| 色综合久久中文综合网| 99精品久久精品一区二区|