青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

poj 2417 Discrete Logging

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


   意思很清楚,就是假設(shè)x = i * m + j,那么方程可以轉(zhuǎn)化為b*(a^-m)^i  = a^j % p。先計算出右邊的值,存儲在一張表里面,
然后從小到大枚舉左邊的i(0<=i<m),率先滿足等式的就是最小的解x。
   poj上面這個題用map存儲(a^j,j)對的時候會超時,改成hash表存儲才能過,額,畢竟理論復(fù)雜度不是一個數(shù)量級的。我的hash表是
開了2個數(shù)組,一個鍵,一個值,用來相互驗證,槽沖突的話,一直往后找位置。感覺這樣的做法沒有鏈?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 閱讀(1189) 評論(0)  編輯 收藏 引用 所屬分類: 數(shù)論

<2012年7月>
24252627282930
1234567
891011121314
15161718192021
22232425262728
2930311234

導(dǎo)航

統(tǒng)計

公告

常用鏈接

留言簿(3)

隨筆分類

隨筆檔案

me

好友

同學(xué)

網(wǎng)友

搜索

最新評論

閱讀排行榜

評論排行榜

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            国产精品永久免费| 欧美午夜精品理论片a级按摩 | 欧美大片91| 香蕉免费一区二区三区在线观看 | 亚洲精选久久| 免费视频一区二区三区在线观看| 一区二区三区四区蜜桃| 欧美日韩国产首页在线观看| 亚洲人成啪啪网站| 欧美激情精品久久久久久免费印度| 久久国产精品久久国产精品| 国产亚洲电影| 久久精品欧美日韩| 久久精品亚洲一区二区| 激情另类综合| 免费看亚洲片| 欧美不卡视频一区| 亚洲精品少妇30p| 亚洲三级视频| 欧美日韩成人一区二区| 亚洲少妇诱惑| 亚洲精品一区二区三| 欧美日韩国产美| 午夜视频一区二区| 久久高清国产| 在线看片一区| 亚洲国产精品第一区二区| 欧美片网站免费| 亚洲欧美国产精品桃花| 性18欧美另类| 亚洲欧洲一区二区天堂久久| 欧美系列一区| 国内精品视频在线播放| 噜噜噜躁狠狠躁狠狠精品视频| 久久全国免费视频| 一区二区三区视频在线| 亚洲一区二区三区午夜| 精品成人一区二区| 亚洲麻豆国产自偷在线| 国产欧美日韩亚洲精品| 欧美激情国产日韩| 国产精品久久波多野结衣| 久久天天躁狠狠躁夜夜爽蜜月| 欧美精品九九99久久| 欧美在线|欧美| 欧美va亚洲va香蕉在线| 午夜亚洲福利| 欧美激情一区二区三区全黄| 先锋资源久久| 男女激情久久| 久久久国产成人精品| 欧美久久综合| 久色成人在线| 国产欧美高清| 亚洲精品四区| 国产中文一区二区| 99视频在线精品国自产拍免费观看| 国产视频一区欧美| 99精品欧美一区| 亚洲韩日在线| 久久国产精彩视频| 亚洲欧美日韩成人| 欧美精品一区二区三区视频| 久久米奇亚洲| 国产麻豆91精品| 最新国产成人在线观看| 国内偷自视频区视频综合| 一区二区三区四区五区在线| 亚洲第一色在线| 性欧美大战久久久久久久免费观看 | 久久久久一区二区三区| 亚洲永久在线观看| 欧美日韩国产成人在线观看| 欧美jizz19性欧美| 国产视频久久网| 亚洲在线观看| 亚洲尤物精选| 国产精品久久久久久一区二区三区| 亚洲国产裸拍裸体视频在线观看乱了中文 | 欧美成人免费在线观看| 国产亚洲成av人在线观看导航| 在线综合视频| 亚洲影音一区| 国产精品久久久| 久久精品中文| 欧美一区二区三区免费大片| 在线视频亚洲| 欧美绝品在线观看成人午夜影视| 欧美大片在线观看| 亚洲欧洲精品一区二区三区波多野1战4 | 一区二区三区高清不卡| 亚洲视频在线视频| 欧美午夜精品理论片a级按摩| 亚洲免费av观看| 亚洲图片欧洲图片av| 欧美视频在线不卡| 亚洲亚洲精品三区日韩精品在线视频| 一区二区欧美日韩| 欧美午夜在线视频| 亚洲欧美在线网| 久久视频一区| 91久久亚洲| 欧美日韩国产美| 亚洲自拍偷拍福利| 久久人91精品久久久久久不卡| 国产主播精品在线| 六月婷婷一区| 99re6这里只有精品| 午夜一区二区三区在线观看| 国产亚洲欧美另类一区二区三区| 欧美在线免费观看| 欧美激情日韩| 亚洲欧美日韩一区二区在线 | 精品电影在线观看| 欧美激情精品久久久久久| 99v久久综合狠狠综合久久| 亚洲欧美一区在线| 一区二区三区在线视频播放| 欧美a级片一区| 亚洲网在线观看| 欧美jizz19hd性欧美| 亚洲夜晚福利在线观看| 国产午夜精品一区理论片飘花| 久久米奇亚洲| 在线亚洲精品| 欧美第一黄网免费网站| 在线视频中文亚洲| 国精品一区二区三区| 欧美伦理91i| 欧美在线播放一区二区| 亚洲精品国久久99热| 久久精品国产亚洲高清剧情介绍| 亚洲欧洲精品一区二区三区波多野1战4| 欧美日韩在线视频首页| 久久久蜜桃精品| 亚洲一区bb| 欧美高清视频在线观看| 亚洲欧美国产va在线影院| 亚洲高清一区二| 国产精品一区视频网站| 男男成人高潮片免费网站| 午夜精品福利视频| 亚洲精品在线观看视频| 久久精品首页| 亚洲欧美日韩精品一区二区| 最新中文字幕亚洲| 韩国v欧美v日本v亚洲v| 国产精品高潮粉嫩av| 欧美顶级少妇做爰| 久久久99久久精品女同性| 亚洲一区二区三区欧美| 亚洲日本电影| 午夜亚洲福利在线老司机| 欧美freesex交免费视频| 亚洲一区美女视频在线观看免费| 亚洲成人影音| 国产一区二区三区免费在线观看| 欧美午夜片在线观看| 欧美大片免费久久精品三p | 亚洲一区中文| 亚洲精品免费网站| 欧美 日韩 国产在线 | 蜜桃久久精品一区二区| 久久riav二区三区| 午夜精品久久久久久久久久久久久| 亚洲欧洲精品一区二区精品久久久 | 欧美亚洲在线播放| 中国av一区| 中文国产成人精品| 一本色道久久综合| 99在线精品视频在线观看| 亚洲精品乱码久久久久久黑人| 亚洲二区在线| 亚洲人成精品久久久久| 91久久精品www人人做人人爽| 影音先锋久久精品| 黄色一区二区三区四区| 韩国v欧美v日本v亚洲v| 国产在线视频不卡二| 狠狠色丁香久久婷婷综合_中| 国产亚洲精品美女| 精品999在线观看| 亚洲国产精品第一区二区| 亚洲国产精品成人| 99视频精品免费观看| 一区二区三区欧美日韩| 亚洲欧美国产制服动漫| 久久精品三级| 亚洲二区在线| 一区二区三区蜜桃网| 欧美在线free| 欧美成人黄色小视频| 欧美日韩中文字幕日韩欧美| 国产精品毛片在线看| 国产一区二区三区网站| 亚洲片在线资源| 午夜性色一区二区三区免费视频| 久久精品视频网| 亚洲国产精品999| 一区二区三区回区在观看免费视频|