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

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>
            亚洲娇小video精品| 久久综合激情| 国产一区二区三区观看| 欧美四级剧情无删版影片| 欧美精品1区| 欧美日韩视频在线观看一区二区三区| 欧美aaa级| 欧美日韩一区二| 国产精品视频xxxx| 狠狠色狠色综合曰曰| 亚洲国产成人不卡| 中国成人黄色视屏| 欧美中文字幕在线播放| 久久午夜电影| 亚洲精品国产精品国产自| 欧美福利网址| 亚洲网站在线观看| 欧美在线视频不卡| 欧美激情精品久久久久久变态| 欧美日韩国产a| 国产网站欧美日韩免费精品在线观看 | 欧美激情第二页| 欧美视频国产精品| 国产视频久久久久| 亚洲欧洲日韩在线| 欧美一区二区三区免费大片| 欧美承认网站| 午夜激情综合网| 欧美激情一区二区三级高清视频| 国产精品露脸自拍| 亚洲剧情一区二区| 久久一区亚洲| 亚洲淫性视频| 欧美精品偷拍| 加勒比av一区二区| 香蕉久久夜色| 亚洲伦理在线| 免费美女久久99| 国语自产精品视频在线看一大j8 | 亚洲激情亚洲| 亚洲午夜精品国产| 欧美国产在线电影| 激情91久久| 欧美一级日韩一级| 亚洲国产精品久久精品怡红院| 亚洲桃色在线一区| 亚洲黄色在线| 欧美1区2区3区| 亚洲福利专区| 六十路精品视频| 性欧美暴力猛交69hd| 欧美午夜影院| 一区二区三区不卡视频在线观看| 久久综合99re88久久爱| 午夜日韩激情| 国产一区二区精品久久91| 午夜精品福利在线| 亚洲小说欧美另类社区| 国产精品swag| 亚洲欧美日韩国产综合| 中文精品99久久国产香蕉| 欧美视频1区| 亚洲欧美综合国产精品一区| 99在线精品视频| av成人黄色| 国产精品久久久久久久久搜平片| 亚洲午夜视频| 亚洲欧美综合v| 激情文学综合丁香| 欧美激情偷拍| 欧美四级伦理在线| 欧美综合激情网| 久久婷婷久久| 亚洲欧美日韩成人| 久久国产精品网站| 亚洲第一成人在线| 亚洲精品国产系列| 欧美视频在线观看 亚洲欧| 亚洲摸下面视频| 亚洲欧美精品| 亚洲国产成人精品女人久久久| 欧美激情按摩| 国产精品成人免费| 噜噜噜噜噜久久久久久91| 欧美~级网站不卡| 亚洲免费影视| 久久综合狠狠综合久久激情| 夜夜嗨一区二区| 久久久久久91香蕉国产| 久久久久久穴| 欧美极品在线播放| 久久国产精品99国产| 猛男gaygay欧美视频| 亚洲免费人成在线视频观看| 欧美永久精品| 一本久久精品一区二区| 欧美激情精品久久久久久久变态| 亚洲视频电影在线| 久久久亚洲国产天美传媒修理工| 亚洲国产另类久久久精品极度| 亚洲激情在线激情| 国产精品美女主播| 欧美+亚洲+精品+三区| 国产精品国产三级国产普通话蜜臀 | 制服丝袜亚洲播放| 在线播放豆国产99亚洲| 99riav1国产精品视频| 激情婷婷欧美| 亚洲综合视频一区| 日韩一区二区免费看| 久久福利资源站| 亚洲免费人成在线视频观看| 免费一级欧美片在线观看| 亚洲欧美日韩综合一区| 欧美激情a∨在线视频播放| 国产精品美女在线观看| 亚洲片国产一区一级在线观看| 国产一区三区三区| 亚洲综合清纯丝袜自拍| 精品96久久久久久中文字幕无| 亚洲精品一区二区三区婷婷月 | 亚洲电影观看| 国产欧美精品在线| 99国内精品久久久久久久软件| 精品91在线| 欧美在线短视频| 午夜精品美女久久久久av福利| 欧美大胆a视频| 亚洲国产高清在线| 亚洲国产裸拍裸体视频在线观看乱了中文 | 亚洲色图自拍| 欧美日韩国产综合网| 欧美黄色成人网| 亚洲高清免费| 欧美va亚洲va日韩∨a综合色| 国产精品一区二区三区久久| 99精品99| 西西人体一区二区| 国产精品视频yy9299一区| 一区二区三区视频观看| 亚洲制服少妇| 国产精品区一区二区三| 午夜精品视频在线观看| 久久精品欧美日韩| 在线成人国产| 欧美日韩亚洲一区二区三区| 亚洲欧洲精品一区| av成人国产| 欧美一区二区三区四区视频| 亚洲人成在线播放| 正在播放亚洲| 亚洲开发第一视频在线播放| 欧美精品一区二区三区视频| 亚洲高清不卡av| 亚洲图片在区色| 国产精品免费aⅴ片在线观看| 亚洲午夜免费视频| 久久久久久午夜| 亚洲精品久久久久久久久| 欧美日韩高清免费| 亚洲一区二区三区四区中文| 久久免费的精品国产v∧| 亚洲电影一级黄| 欧美日韩另类视频| 午夜在线电影亚洲一区| 亚洲二区视频| 欧美日本一区二区三区| 亚洲欧美成人| 欧美激情区在线播放| 亚洲午夜极品| 在线观看欧美亚洲| 欧美日韩在线一区| 久久亚洲一区| 这里只有精品丝袜| 欧美阿v一级看视频| 久久久999精品| 亚洲高清久久| 国产日韩精品一区二区浪潮av| 久久伊人免费视频| 亚洲网站视频| 亚洲国产精品成人久久综合一区| 亚洲欧美日韩国产中文在线| 在线电影国产精品| 国产精品美女在线观看| 欧美第一黄网免费网站| 新狼窝色av性久久久久久| 亚洲人成网站在线观看播放| 午夜视频在线观看一区| 日韩视频专区| 在线观看精品| 国产区亚洲区欧美区| 欧美日韩不卡一区| 蜜桃精品久久久久久久免费影院| 亚洲自拍偷拍麻豆| 亚洲最新视频在线| 欧美激情在线狂野欧美精品| 国产一区二区三区成人欧美日韩在线观看 | 欧美freesex8一10精品| 欧美一区二区三区免费大片| 亚洲免费av片|