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

Omni Inspirations

problems & programs ~

統(tǒng)計(jì)

留言簿

Friends

閱讀排行榜

評論排行榜

Pku 2417 Discrete Logging

題意:
求最小的離散對數(shù)B 使得A^B == C (mod P)  P是質(zhì)數(shù) 或者判無解

做法:

數(shù)論題..對于比我大的同學(xué)肯定覺得很簡單。。
由歐拉定理 A^phi(P) == 1 (mod P) (phi(prime)=prime-1)
得到 A^(B+phi(P)) == c (mod P)   A^(B-Phi(P)) ==c (mod P)
所以可以肯定的一點(diǎn)是 如果 [0,phi(P))內(nèi)無解 由此式子的周期性必然不會有更多解

一個樸素的想法:枚舉 B∈[0,phi(P)) 檢驗(yàn) A^B是否 == C(mod P)
問題又出現(xiàn)了 P是個質(zhì)數(shù) phi(P)=P-1  必然TLE
所以就必須用空間換時間。

設(shè)得到的答案是B  B=X*sqrt(P)+Y 注意到X,Y<=sqrt(P)
列式并化簡:

A^(X*sqrt(P)+Y) == C (mod P)
(A*sqrt(P))^X*A^Y == C (mod P)

設(shè) T=A*sqrt(P) 原式即 T^X*A^Y == C (mod P)
兩邊同除以 A^Y  得到 T^X == C/(A^Y) (mod P)

好吧 到現(xiàn)在 做法就已經(jīng)浮出水面了

我們預(yù)處理T^i (mod P) 最多sqrt(P)個 (i<X)
手寫hash或者用map直接存下來二元組 (T^X (mod P),X)

然后枚舉 Y∈[0,sqrt(P)) 最多sqrt(P)個
對于每個Y 我們求出 C/(A^Y) (mod P)  然后在hash或者map中查找這個值
如果 (C/(A^Y) (mod P),X) 存在  那么說明 X*sqrt(P)+Y 是可以作為答案的

最后答案便是所有滿足條件的 X*sqrt(P)+Y 中的最小值。

如果你不知道 C/(A^Y) (mod P) 怎么求
那就繼續(xù)看下去吧
C/(A^Y) (mod P) == C*((1/A^Y) mod P)
(1/A^Y) (mod P) == (A^Y)^-1 (mod P)
即 (A^Y)^(phi(P)-1) (mod P)
所以 C/(A^Y) (mod P) 就等于C*(A^Y)^(phi(P)-1) (mod P)

這樣就解決了此題。

 1 #include <cstdio>
 2 #include <cstring>
 3 #include <cmath>
 4 #define Prime 899037
 5 #define oo 2000000005
 6 #define min(a,b) ((a)<(b)?(a):(b))
 7 int P,B,N;
 8 int H[Prime],V[Prime];
 9 inline int pow(int u,int v)
10 {
11     int ret=1;
12     for (int tmp=u;v;v>>=1,tmp=(tmp*(long long)tmp)%P)
13     if (v&1)    ret=(ret*(long long)tmp)%P;
14     return ret;
15 }
16 inline void Hpush(int u,int v)
17 {
18     int t=u%Prime;
19     for (;H[t];)
20     {
21         if (H[t]==u)    return;
22         if (++t==P)    t-=P;
23     }
24     H[t]=u,V[t]=v;
25 }
26 inline int Hpop(int u)
27 {
28     int t=u%Prime;
29     for (;H[t];)
30     {
31         if (H[t]==u)    return V[t];
32         if (++t==P)    t-=P;
33     }
34     return oo;
35 }
36 int main()
37 {
38     for (;scanf("%d%d%d",&P,&B,&N)!=EOF;)
39     {
40         int ret=oo+1;
41         memset(H,0,sizeof(H));
42         memset(V,-1,sizeof(V));
43         int sqrtP=(int)sqrt((double)P),Bsp=pow(B,sqrtP);
44         for (int i=0,val=1;i<=sqrtP;++i,val=(val*(long long)Bsp)%P)
45             Hpush(val,i);
46         for (int i=0,val=1;i<=sqrtP;++i,val=(val*(long long)B)%P)
47         {
48             int h=(N*(long long)pow(val,P-2))%P,v=Hpop(h);
49             if (v<oo&&v*sqrtP+i<ret)    ret=v*sqrtP+i;
50         }
51         if (ret>oo)    puts("no solution");
52         else    printf("%d\n",ret);
53     }
54     return 0;
55 }
56 

posted on 2010-04-21 14:58 jsn1993 閱讀(399) 評論(0)  編輯 收藏 引用 所屬分類: Math

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            伊人久久大香线蕉综合热线 | 久久久久国产一区二区| 在线高清一区| 激情久久五月| 一区在线免费| 亚洲级视频在线观看免费1级| 18成人免费观看视频| 亚洲国产日韩欧美在线动漫| 国内揄拍国内精品少妇国语| 亚洲激情电影在线| av成人免费在线| 欧美一区二区三区在线看| 久久精品国产69国产精品亚洲| 久久久久一区二区三区四区| 欧美福利网址| 亚洲在线网站| 欧美国产日产韩国视频| 中文国产成人精品| 国产亚洲精品一区二区| 伊人精品在线| 亚洲视屏一区| 欧美成人午夜77777| 一本一本久久a久久精品综合麻豆| 午夜精品国产更新| 欧美精品一区三区| 黄色成人在线网址| 亚洲专区欧美专区| 欧美aa在线视频| 亚洲女人天堂av| 欧美日韩精品一二三区| 国内精品久久久| 亚洲欧美色婷婷| 亚洲激情成人网| 欧美亚洲午夜视频在线观看| 欧美77777| 一区二区三区在线视频播放| 亚洲男人天堂2024| 亚洲黄一区二区三区| 欧美一区永久视频免费观看| 欧美无砖砖区免费| 亚洲久久一区二区| 欧美黄色一区| 久久综合九色综合久99| 国产午夜精品视频| 西瓜成人精品人成网站| 91久久在线观看| 美女视频黄免费的久久| 激情综合色综合久久| 亚洲欧美文学| 一区二区久久久久久| 欧美肥婆在线| 日韩视频免费观看高清在线视频 | 1024成人| 快播亚洲色图| 久久久综合精品| 国产一区二区三区免费不卡| 午夜视频一区| 午夜精品久久久久久久久久久久久 | 一区二区三区在线看| 久久精品国产2020观看福利| 亚洲精品免费在线播放| 久久久久综合| 国产欧美日韩精品在线| 日韩视频免费看| 麻豆成人91精品二区三区| 99riav久久精品riav| 麻豆成人av| 好吊视频一区二区三区四区 | 99精品视频网| 久久久精品一区二区三区| 亚洲精品午夜| 欧美日本一道本在线视频| 国产精品99久久久久久久久| 亚洲午夜在线| 国产字幕视频一区二区| 免费中文日韩| 欧美日韩免费看| 欧美日韩1区2区| 国内精品视频666| 欧美亚洲免费电影| 久久成人免费视频| 亚洲人成网站影音先锋播放| 亚洲精品乱码久久久久久黑人| 国产精品高清在线观看| 久久久精品日韩| 欧美国产乱视频| 欧美在线地址| 欧美激情1区2区3区| 香蕉久久夜色精品| 免费看的黄色欧美网站| 亚洲欧美日韩一区在线| 久久久久久国产精品mv| 夜夜爽av福利精品导航| 欧美一区二区久久久| 亚洲精品中文字幕女同| 午夜视黄欧洲亚洲| 亚洲毛片视频| 久久gogo国模裸体人体| 亚洲一区二区三区在线看| 久久久国产成人精品| 在线一区欧美| 久久综合九色综合久99| 午夜欧美电影在线观看| 欧美顶级艳妇交换群宴| 久久麻豆一区二区| 欧美午夜视频网站| 亚洲高清视频一区| 激情综合在线| 香蕉久久国产| 亚洲欧美久久久| 欧美了一区在线观看| 久久性天堂网| 国产精品永久免费观看| 亚洲精品日韩在线观看| 亚洲国产精品精华液网站| 亚洲免费人成在线视频观看| 日韩一本二本av| 女女同性女同一区二区三区91| 欧美一区在线直播| 国产精品成人aaaaa网站| 欧美激情二区三区| 亚洲国产精品久久人人爱蜜臀| 午夜精品一区二区三区在线播放 | 亚洲精品久久久久中文字幕欢迎你| 国产自产v一区二区三区c| 亚洲一区二区高清视频| 一区二区三区蜜桃网| 亚洲第一页在线| 欧美成人精品不卡视频在线观看| 国产精品久久二区二区| 最新中文字幕一区二区三区| 在线免费一区三区| 久久精品欧洲| 久久综合久久综合久久| 国产亚洲欧洲| 欧美一区二区三区另类| 久久国产一区二区| 国产欧美精品| 欧美在线啊v一区| 美女被久久久| 亚洲第一成人在线| 六月婷婷一区| 亚洲激情在线观看视频免费| 日韩视频免费大全中文字幕| 欧美激情小视频| 亚洲三级视频在线观看| 夜夜嗨av一区二区三区四季av| 欧美精品亚洲| 在线一区日本视频| 欧美在线视频免费播放| 国产九色精品成人porny| 欧美一级久久久久久久大片| 久久亚洲色图| 亚洲激情视频网站| 欧美日韩第一页| 亚洲一区二区三区免费视频| 欧美在线三区| 亚洲国内欧美| 国产精品久久久久久久久借妻| 亚洲欧美日韩系列| 免费亚洲视频| 国产精品99久久久久久久久| 国产精品v欧美精品v日韩| 亚洲欧美资源在线| 欧美成人精品不卡视频在线观看| 亚洲精品影院| 国产精品一区二区三区成人| 久久久久久网| 一区二区精品国产| 免费亚洲电影在线观看| 亚洲视频一二三| 红桃视频国产精品| 欧美日韩国产欧| 欧美在线观看日本一区| 日韩视频永久免费观看| 久久精品国产一区二区三区免费看| 在线精品亚洲一区二区| 欧美丝袜一区二区| 久久综合久久美利坚合众国| 亚洲一区二区三区高清 | 日韩视频亚洲视频| 久久综合久色欧美综合狠狠 | 久久午夜电影网| 亚洲午夜一区| 亚洲精品欧美专区| 久久久水蜜桃av免费网站| 日韩一级二级三级| 狠狠操狠狠色综合网| 欧美视频精品一区| 麻豆成人小视频| 久久精品女人天堂| 亚洲欧美经典视频| 正在播放亚洲一区| 99re热精品| 99re这里只有精品6| 亚洲欧美在线播放| 欧美日韩亚洲在线| 久久久久五月天| 亚洲一区二区在线看| 最新日韩在线视频|