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

poj 2417 Discrete Logging

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


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

<2012年5月>
293012345
6789101112
13141516171819
20212223242526
272829303112
3456789

導航

統計

公告

常用鏈接

留言簿(3)

隨筆分類

隨筆檔案

me

好友

同學

網友

搜索

最新評論

閱讀排行榜

評論排行榜

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            国产精品福利网站| 午夜精品久久久久久99热| 麻豆成人av| 欧美在线精品一区| 羞羞答答国产精品www一本| 国产精品99久久久久久有的能看| 亚洲国产婷婷| 欧美va天堂| 亚洲精美视频| 亚洲色无码播放| 欧美亚洲一区二区在线| 久久久精品日韩欧美| 欧美1区2区| 欧美午夜在线| 狠狠色狠狠色综合日日91app| 精品av久久707| 日韩一级黄色av| 欧美人与性动交a欧美精品| 欧美激情精品久久久久久大尺度| 欧美大片在线观看一区| 欧美国产极速在线| 久久国产精品色婷婷| 亚洲欧美卡通另类91av| 午夜国产精品影院在线观看| 久久视频在线视频| 欧美精品综合| 国产一区二区欧美日韩| 亚洲日本va午夜在线电影| 亚洲欧美日本国产有色| 欧美.www| 亚洲欧美区自拍先锋| 欧美精品18| 激情成人中文字幕| 午夜精品久久久久久久99水蜜桃 | 欧美14一18处毛片| 国产精品免费一区二区三区观看| 伊人久久综合| 午夜精品国产更新| 亚洲精品一区二区三区四区高清| 久久国产直播| 国产精品视频你懂的| 亚洲国产精品女人久久久| 欧美一区二区三区在线播放| 亚洲人成网站999久久久综合| 亚洲欧美激情一区| 国产精品福利av| 中文一区二区| 亚洲精品日韩综合观看成人91| 久久久久久一区二区| 国产一区二区观看| 欧美一区二区免费视频| 亚洲一区二区三区免费在线观看| 欧美精品一线| 一区二区三区不卡视频在线观看| 91久久线看在观草草青青| 美女主播视频一区| 亚洲国产女人aaa毛片在线| 免费看精品久久片| 免费美女久久99| 亚洲精品国产拍免费91在线| 亚洲国产黄色片| 欧美区在线观看| 亚洲精品字幕| 亚洲看片免费| 国产精品亚洲一区二区三区在线| 亚洲欧美日韩国产精品| 国产精品99久久久久久久久久久久| 欧美美女bbbb| 午夜精品久久久久久久99水蜜桃| 亚洲视频免费在线| 国产精品视频成人| 久久亚洲私人国产精品va| 国产主播精品在线| 亚洲在线成人| 亚洲欧美国产日韩中文字幕| 国产亚洲精品久久久| 久久深夜福利免费观看| 卡一卡二国产精品| 亚洲乱码精品一二三四区日韩在线| 亚洲第一狼人社区| 欧美视频一区二区三区在线观看 | 久久婷婷丁香| 巨胸喷奶水www久久久免费动漫| 一区二区三区亚洲| 欧美肥婆在线| 欧美日韩中文字幕精品| 欧美亚洲在线观看| 久久婷婷国产麻豆91天堂| 亚洲精品久久在线| 亚洲一区二区三区在线播放| 伊甸园精品99久久久久久| 亚洲欧洲日韩女同| 国产精品一区二区三区观看| 久久手机精品视频| 欧美日韩激情网| 久久久久久一区二区| 欧美高清成人| 久久久91精品国产一区二区三区 | 欧美顶级少妇做爰| 亚洲一区尤物| 久久一综合视频| 亚洲一区二区三区色| 久久精品日韩欧美| 一区二区三区四区五区在线| 久久gogo国模裸体人体| 在线视频亚洲一区| 久久这里只有| 久久成人18免费网站| 欧美国产精品一区| 久久久久一区二区三区| 欧美视频一区二区三区| 欧美激情精品久久久久| 国产午夜精品全部视频在线播放| 亚洲人成在线影院| 在线看欧美日韩| 性欧美暴力猛交另类hd| 亚洲视频一区在线观看| 久久久久久国产精品一区| 午夜一区不卡| 欧美色偷偷大香| 亚洲欧洲日本国产| 亚洲国产精品精华液网站| 午夜精品一区二区三区在线播放 | 欧美午夜免费影院| 欧美激情1区| 精久久久久久| 欧美一级免费视频| 午夜欧美大片免费观看| 国产精品伊人日日| 国产精品久久久久久久9999| 欧美v亚洲v综合ⅴ国产v| 国产精品视频第一区| 一本色道久久综合精品竹菊| 日韩一级大片在线| 欧美激情综合色综合啪啪| 欧美成人午夜| 亚洲大片在线观看| 久久婷婷国产综合国色天香| 久久视频在线视频| 在线观看亚洲a| 久久久天天操| 你懂的成人av| 亚洲精品在线免费| 欧美日韩亚洲综合一区| 9l视频自拍蝌蚪9l视频成人| 在线性视频日韩欧美| 欧美视频中文字幕| 亚洲免费在线视频| 久久久一本精品99久久精品66| 国产一区二区av| 久久视频国产精品免费视频在线| 欧美成人精品h版在线观看| 亚洲国产欧美一区二区三区同亚洲| 久久亚洲精选| 亚洲国产婷婷香蕉久久久久久99| 亚洲麻豆视频| 国产精品红桃| 久久精品视频网| 亚洲另类在线一区| 国产精品成人观看视频免费| 最新国产の精品合集bt伙计| 亚洲黄色免费电影| 免播放器亚洲| 亚洲精品久久| 亚洲香蕉成视频在线观看| 国产精品xxxxx| 欧美一区二区在线观看| 欧美国产日韩一区| 一区二区日韩精品| 国产日韩欧美一区| 另类酷文…触手系列精品集v1小说| 欧美激情网友自拍| 亚洲欧美日韩专区| 激情久久影院| 欧美午夜精品久久久久久孕妇| 久久午夜视频| 亚洲第一黄色网| 在线亚洲+欧美+日本专区| 国产伦精品一区二区三区在线观看 | 日韩网站在线| 久久精品一区蜜桃臀影院| 亚洲高清在线视频| 欧美视频一区二区三区在线观看| 午夜精品理论片| 性欧美精品高清| 亚洲嫩草精品久久| 久久色在线播放| 一本久久综合亚洲鲁鲁| 国产模特精品视频久久久久 | 亚洲人成小说网站色在线| 国产精品yjizz| 巨乳诱惑日韩免费av| 亚洲一区国产视频| 91久久久久| 欧美大成色www永久网站婷| 亚洲一区二区三区中文字幕| 亚洲国产精品第一区二区| 国产日韩欧美在线视频观看| 欧美日韩精品免费在线观看视频| 久久久精品国产免大香伊|