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

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)無解 由此式子的周期性必然不會有更多解

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

設(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)個(gè) (i<X)
手寫hash或者用map直接存下來二元組 (T^X (mod P),X)

然后枚舉 Y∈[0,sqrt(P)) 最多sqrt(P)個(gè)
對于每個(gè)Y 我們求出 C/(A^Y) (mod P)  然后在hash或者map中查找這個(gè)值
如果 (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>
            久久免费少妇高潮久久精品99| 亚洲精品日产精品乱码不卡| 欧美午夜精品久久久久久人妖 | 国产精品综合久久久| 欧美激情第1页| 欧美午夜理伦三级在线观看| 国产精品日韩电影| 在线欧美视频| 亚洲视频国产视频| 久久精品夜夜夜夜久久| 亚洲国产1区| 日韩一级黄色av| 亚洲一级高清| 免费在线欧美视频| 国产精品久久久久一区| 在线精品国产欧美| 亚洲欧美日韩一区二区在线| 久久综合久色欧美综合狠狠| 亚洲精品少妇网址| 久久久99精品免费观看不卡| 欧美日韩亚洲网| 海角社区69精品视频| 亚洲视频999| 久久一区免费| 亚洲视频一区二区在线观看| 久久天天躁狠狠躁夜夜av| 欧美日韩在线不卡| 亚洲人成免费| 久久综合影音| 午夜视频在线观看一区| 欧美日韩国产一区二区| 在线成人av| 久久精品道一区二区三区| 日韩亚洲综合在线| 欧美jizz19性欧美| 国外成人免费视频| 欧美一级黄色网| 日韩香蕉视频| 欧美精品久久久久久久久久| 在线观看亚洲| 久久伊伊香蕉| 欧美诱惑福利视频| 国产私拍一区| 午夜日韩福利| 中文高清一区| 国产精品www994| 亚洲社区在线观看| 亚洲精品在线免费观看视频| 欧美福利视频在线| 亚洲国产另类精品专区| 国语自产在线不卡| 久久精品女人的天堂av| 亚洲欧美日韩精品一区二区| 国产精品久久久爽爽爽麻豆色哟哟 | 日韩香蕉视频| 亚洲第一成人在线| 久久噜噜亚洲综合| 黑人巨大精品欧美一区二区| 欧美在线视频观看| 亚洲一区二区三区精品在线| 欧美四级伦理在线| 亚洲欧美日韩国产精品 | 精品成人一区二区| 亚洲欧美综合网| 亚洲欧美激情视频在线观看一区二区三区| 日韩一区二区电影网| 亚洲人成小说网站色在线| 美女在线一区二区| 亚洲精品一品区二品区三品区| 日韩一区二区免费高清| 欧美激情视频免费观看| 免费在线亚洲欧美| 夜夜嗨av色综合久久久综合网| 亚洲一区二区三区高清| 亚洲青色在线| 欧美视频你懂的| 欧美中文字幕视频在线观看| 久久国产一区二区| 亚洲另类在线视频| 亚洲一区二区三区欧美| 国产亚洲免费的视频看| 欧美大片免费| 国产精品扒开腿做爽爽爽软件| 在线观看一区视频| 亚洲激情国产精品| 国产精品毛片va一区二区三区| 在线观看国产一区二区| 亚洲国产欧美一区二区三区久久 | 久久综合狠狠| 男女激情视频一区| 亚洲一区二区成人在线观看| 午夜一区二区三视频在线观看| 欧美日韩成人激情| 欧美与欧洲交xxxx免费观看| 久久综合色综合88| 欧美一区二区三区日韩视频| 久久综合九色综合久99| 中文在线一区| 久久久蜜桃一区二区人| av成人免费在线观看| 欧美一区二区| 亚洲综合不卡| 欧美国产日韩一区二区三区| 久久精品国产欧美激情| 亚洲国产精品电影在线观看| 欧美性理论片在线观看片免费| 精品成人免费| 一本久久a久久精品亚洲| 精品99视频| 亚洲一区二区三区777| 精品成人国产| 午夜精品久久久久久99热| 亚洲美女福利视频网站| 性欧美大战久久久久久久免费观看| 国产精品久久久久久久app | 久久成人免费电影| 欧美大片va欧美在线播放| 久久久精品日韩| 国产精品劲爆视频| 亚洲精品社区| 亚洲欧洲视频| 久久九九国产精品| 久久一区二区三区四区| 国产人成一区二区三区影院| 亚洲视频在线观看免费| 亚洲一级黄色av| 欧美三级在线播放| 日韩天堂在线观看| 亚洲神马久久| 欧美性jizz18性欧美| 亚洲精品日日夜夜| 在线视频精品一区| 欧美日韩在线观看一区二区| 亚洲久久一区二区| 亚洲视频在线观看三级| 欧美日本国产一区| 日韩网站在线看片你懂的| 亚洲每日在线| 欧美日韩一区在线观看| 一本久久综合亚洲鲁鲁五月天| 国产欧美日韩在线观看| 亚洲曰本av电影| 欧美在线精品免播放器视频| 国产精品亚洲产品| 久久国产精品99国产| 久久亚洲精品伦理| 亚洲国产日韩一区| 欧美人与禽猛交乱配视频| 亚洲美女视频在线观看| 亚洲欧美在线免费| 国产在线不卡精品| 欧美成黄导航| 亚洲午夜视频在线观看| 久久精品一区二区三区不卡| 1024精品一区二区三区| 欧美日韩第一区| 亚洲欧美精品伊人久久| 欧美成人日韩| 亚洲午夜精品| 国内自拍一区| 欧美日韩免费观看一区=区三区 | 久久久久久久综合色一本| 国产欧美丝祙| 免费视频一区| 国产精品99久久久久久人| 久久精品主播| 99视频精品在线| 国产亚洲毛片在线| 欧美激情在线免费观看| 午夜精品理论片| 免费日韩av| 狠狠色狠狠色综合日日五| 久久人人97超碰国产公开结果| 欧美一区三区二区在线观看| 久久婷婷成人综合色| 99视频精品免费观看| 国产精品理论片| 鲁鲁狠狠狠7777一区二区| 宅男66日本亚洲欧美视频| 麻豆精品在线观看| 亚洲影院色无极综合| 亚洲第一页在线| 国产视频一区二区在线观看| 欧美精品一区二区三区四区| 久久国产精品久久久久久久久久 | 国产精品成人播放| 久久久噜噜噜久久| 在线一区亚洲| 亚洲第一搞黄网站| 久久婷婷综合激情| 先锋影音久久| 一区二区三区欧美日韩| 在线精品国产成人综合| 国产一区在线免费观看| 国产伦一区二区三区色一情| 国产精品高潮呻吟久久av无限| 亚洲一区三区电影在线观看| 亚洲国产精品毛片| 欧美成人久久| 欧美大色视频|