{"id":314,"date":"2010-07-21T18:37:00","date_gmt":"2010-07-21T10:37:00","guid":{"rendered":"http:\/\/localhost\/?p=314"},"modified":"2010-07-21T18:37:00","modified_gmt":"2010-07-21T10:37:00","slug":"sgu_261_discrete_roots","status":"publish","type":"post","link":"https:\/\/www.shuizilong.com\/wjmzbmr\/?p=314","title":{"rendered":"SGU 261. Discrete Roots"},"content":{"rendered":"<p> \u7ed9\u4e00\u4e2a\u7d20\u6570p\uff0c\u6574\u6570k\u548ca<br \/>\u5c31x^k=a(mod p)\u7684\u6240\u6709\u6574\u6570\u89e3\u3002\u3002\u3002<br \/>\u9996\u5148\u7b97\u51fa\u539f\u6839g<br \/>\u8bbex=g^i(mod p)<br \/>\u5219\u9996\u5148\u82e5a==0(\u6211\u5c31\u662f\u5fd8\u5904\u7406\u8fd9\u4e2a\u6240\u4ee5WAN\u6b21\u56e7\u3002\u3002)\u3002\u3002\u90a3\u4e48\u7b54\u6848\u5c31\u662f0.\u3002<br \/>\u5426\u5219a=g^j(mod p)<br \/>\u90a3\u4e48g^(ik)=g^j<br \/>&lt;=&gt; ik=j(mod p-1)..<br \/>\u7b97\u51fa\u6240\u6709\u6ee1\u8db3\u8fd9\u4e2a\u7684i\uff0c\u4ee3\u5165\u5f97\u5230\u6240\u6709x\uff0c\u6392\u5e8f\u5c31OK\u4e86\u3002\u3002<br \/>Code\uff1a<br \/>#include &lt;vector&gt;<br \/>#include &lt;algorithm&gt;<br \/>#include &lt;utility&gt;<br \/>#include &lt;iostream&gt;<br \/>#include &lt;cstdio&gt;<br \/>#include &lt;cmath&gt;<br \/>#include &lt;cstdlib&gt;<br \/>#include &lt;set&gt;<br \/>#include &lt;map&gt;<br \/>#include &lt;cstring&gt;<br \/>#include &lt;time.h&gt;<br \/>#define rep(i,n) for(int i=0;i&lt;n;i++)<br \/>#define pb push_back<br \/>#define Debug(x) cout&lt;&lt;#x&lt;&lt;&quot;=&quot;&lt;&lt;x&lt;&lt;endl;<br \/>#define tr(e,x) for(typeof(x.begin()) e=x.begin();e!=x.end();e++)<br \/>const int inf=~0U&gt;&gt;1,maxn=20;<br \/>using namespace std;<br \/>typedef long long ll;<br \/>ll P[maxn],m=0,p,g,k,a;<br \/>void decompose(ll x)<br \/>{<br \/>    for(ll i=2;i*i&lt;=x;i++)<br \/>        if(x%i==0)<br \/>        {<br \/>            P[m++]=i;<br \/>            while(x%i==0)x\/=i;<br \/>        }<br \/>    if(x&gt;1)P[m++]=x;<br \/>}<br \/>ll ext_gcd(ll a,ll b,ll&amp;x,ll&amp;y)<br \/>{<br \/>    if(!b){x=1;y=0;return a;}<br \/>    ll tmp=ext_gcd(b,a%b,y,x);y-=x*(a\/b);<br \/>    return tmp;<br \/>}<br \/>ll pow(ll x,ll e)<br \/>{<br \/>    if(!e)return 1;<br \/>    ll tmp=pow(x,e\/2);tmp*=tmp;tmp%=p;<br \/>    if(e&amp;1)tmp*=x,tmp%=p;<br \/>    return tmp;<br \/>}<br \/>ll inv(ll x)<br \/>{<br \/>    return pow(x,p-2);<br \/>}<br \/>bool IsRoot(ll a)<br \/>{<br \/>    rep(i,m)<br \/>        if(pow(a,(p-1)\/P[i])==1)return false;<br \/>    return true;<br \/>}<br \/>void FindRoot()<br \/>{<br \/>    decompose(p-1);<br \/>    for(ll i=2;i&lt;p;i++)if(IsRoot(i)){g=i;break;}<br \/>}<br \/>ll discrete_Log(ll a)<br \/>{<br \/>    map&lt;ll,ll&gt; Map;ll M=sqrt(p)+1;<br \/>    ll v=inv(pow(g,M));<br \/>    ll e=1;Map[1]=0;<br \/>    for(ll i=1;i&lt;M;i++){e=e*g%p;if(!Map.count(e))Map[e]=i;}<br \/>    for(ll i=0;i&lt;M;i++)<br \/>    {<br \/>        if(Map.count(a))return i*M+Map[a];<br \/>        a=a*v%p;<br \/>    }<br \/>    return -1;<br \/>}<br \/>vector&lt;ll&gt; Solve(ll a,ll b,ll m)<br \/>{<br \/>    ll x,y,d;<br \/>    d=ext_gcd(a,m,x,y);<br \/>    vector&lt;ll&gt; A;<br \/>    if(b%d)return A;<br \/>    ll t=b\/d;x%=m;if(x&lt;0)x+=m;x=x*t%m;<br \/>    rep(i,d)<br \/>    {<br \/>        A.pb(x);<br \/>        x+=m\/d;x%=m;<br \/>    }<br \/>    return A;<br \/>}<br \/>int main()<br \/>{<br \/>    \/\/freopen(&quot;in&quot;,&quot;r&quot;,stdin);<br \/>    cin&gt;&gt;p&gt;&gt;k&gt;&gt;a;<br \/>    if(a==0){cout&lt;&lt;1&lt;&lt;endl&lt;&lt;0&lt;&lt;endl;return 0;}<br \/>    FindRoot();<br \/>    ll Loga=discrete_Log(a);<br \/>    vector&lt;ll&gt; Logx=Solve(k,Loga,p-1);<br \/>    cout&lt;&lt;Logx.size()&lt;&lt;endl;<br \/>    vector&lt;ll&gt; Ans;<br \/>    tr(it,Logx)<br \/>    {<br \/>        ll tmp=pow(g,*it);<br \/>        Ans.pb(tmp);<br \/>    }<br \/>    sort(Ans.begin(),Ans.end());<br \/>    tr(it,Ans)cout&lt;&lt;*it&lt;&lt;endl;<br \/>}<\/p>\n","protected":false},"excerpt":{"rendered":"<p>\u7ed9\u4e00\u4e2a\u7d20\u6570p\uff0c\u6574\u6570k\u548ca\u5c31x^k=a(mod p)\u7684\u6240\u6709\u6574\u6570\u89e3\u3002\u3002\u3002\u9996\u5148\u7b97\u51fa\u539f\u6839g\u8bbex=g^i(mod p)\u5219\u9996\u5148\u82e5a==0(\u6211\u5c31\u662f\u5fd8\u5904\u7406\u8fd9\u4e2a\u6240\u4ee5WAN\u6b21\u56e7\u3002\u3002)\u3002\u3002\u90a3\u4e48\u7b54\u6848\u5c31\u662f0.\u3002\u5426\u5219a=g^j(mod p)\u90a3\u4e48g^(ik)=g^j&lt;=&gt; ik=j(mod p-1)..\u7b97\u51fa\u6240\u6709\u6ee1\u8db3\u8fd9\u4e2a\u7684i\uff0c\u4ee3\u5165\u5f97\u5230\u6240\u6709x\uff0c\u6392\u5e8f\u5c31OK\u4e86\u3002\u3002Code\uff1a#include &lt;vector&gt;#include &lt;algorithm&gt;#include &lt;utility&gt;#include &lt;iostream&gt;#include &lt;cstdio&gt;#include &lt;cmath&gt;#include &lt;cstdlib&gt;#include &lt;set&gt;#include &lt;map&gt;#include &lt;cstring&gt;#include &lt;time.h&gt;#define rep(i,n) for(int i=0;i&lt;n;i++)#define pb push_back#define Debug(x) cout&lt;&lt;#x&lt;&lt;&quot;=&quot;&lt;&lt;x&lt;&lt;endl;#define tr(e,x) for(typeof(x.begin()) e=x.begin();e!=x.end();e++)const int inf=~0U&gt;&gt;1,maxn=20;using namespace std;typedef long long ll;ll P[maxn],m=0,p,g,k,a;void decompose(ll x){ for(ll i=2;i*i&lt;=x;i++) if(x%i==0) { P[m++]=i; while(x%i==0)x\/=i; } if(x&gt;1)P[m++]=x;}ll ext_gcd(ll a,ll b,ll&amp;x,ll&amp;y){ if(!b){x=1;y=0;return a;} ll tmp=ext_gcd(b,a%b,y,x);y-=x*(a\/b); return tmp;}ll pow(ll [&hellip;]<\/p>\n","protected":false},"author":1,"featured_media":0,"comment_status":"open","ping_status":"open","sticky":false,"template":"","format":"standard","meta":[],"categories":[10],"tags":[],"jetpack_featured_media_url":"","_links":{"self":[{"href":"https:\/\/www.shuizilong.com\/wjmzbmr\/index.php?rest_route=\/wp\/v2\/posts\/314"}],"collection":[{"href":"https:\/\/www.shuizilong.com\/wjmzbmr\/index.php?rest_route=\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/www.shuizilong.com\/wjmzbmr\/index.php?rest_route=\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/www.shuizilong.com\/wjmzbmr\/index.php?rest_route=\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"https:\/\/www.shuizilong.com\/wjmzbmr\/index.php?rest_route=%2Fwp%2Fv2%2Fcomments&post=314"}],"version-history":[{"count":0,"href":"https:\/\/www.shuizilong.com\/wjmzbmr\/index.php?rest_route=\/wp\/v2\/posts\/314\/revisions"}],"wp:attachment":[{"href":"https:\/\/www.shuizilong.com\/wjmzbmr\/index.php?rest_route=%2Fwp%2Fv2%2Fmedia&parent=314"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/www.shuizilong.com\/wjmzbmr\/index.php?rest_route=%2Fwp%2Fv2%2Fcategories&post=314"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/www.shuizilong.com\/wjmzbmr\/index.php?rest_route=%2Fwp%2Fv2%2Ftags&post=314"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}