Baby step , Giant step

來源:互聯網
上載者:User

/*<br />a ^ x = n (mod p)<br />計算x,該代碼僅解決p為素數<br />*/<br />#include <string.h><br />#include <stdio.h><br />#include <math.h><br />#include <algorithm><br />#include <iostream><br />using namespace std;<br />typedef struct { int res, times; } rem;<br />typedef __int64 LL;<br />rem r[1000001];<br />bool cmp(rem r1 , rem r2)<br />{<br />if (r1.res == r2.res)<br />return r1.times < r2.times;<br />return r1.res < r2.res;<br />}<br />int binary(int x , int e)<br />{<br />int s = 0 , mid , ans = -1;<br />while (s <= e)<br />{<br />mid = (s + e) >> 1;<br />if (r[mid].res > x)<br />e = mid - 1;<br />else<br />s = mid + 1;<br /> if (r[mid].res == x)<br /> ans = r[mid].times;<br />}<br />return ans;<br />}<br />int power(LL a,int b,int p)<br />{<br />LL ans = 1;<br />while (b)<br />{<br />while (!(b&1))<br />{<br />b >>= 1;<br />a = a * a % p;<br />}<br />b --;<br />ans = ans * a % p;<br />}<br />return ans;<br />}<br />int main()<br />{<br />int i , j , n , m , sq , p , a , asq , tmp;<br />while (scanf("%d%d%d" , &a , &p , &n)!= EOF)<br />{<br />a %= p;<br />n %= p;<br />sq = (int)ceil(sqrt(double(p)));<br />j = n;<br />r[0].res = n;<br />r[0].times = 0;<br />for (i = 1;i <= sq;i ++)<br />{<br />j = (LL)j * a % p;<br />r[i].res = j;<br />r[i].times = i;<br />}<br />sort(r , r + sq + 1 , cmp);<br />asq = power(a , sq , p);<br />j = 1;<br />for (i = 1;i <= sq;i ++)<br />{<br />j = (LL)j * asq % p;<br />tmp = binary(j , sq);<br />if (tmp + 1) break;<br />}<br />if (i > sq) printf("NONE/n");<br />else printf("%d/n" , i * sq - tmp);<br />}<br />return 0;<br />}

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.