Pagini recente » Borderou de evaluare (job #1420565) | vs_12_lmk | Borderou de evaluare (job #1510040) | Borderou de evaluare (job #2183656) | Cod sursa (job #815579)
Cod sursa(job #815579)
#include <cstdio>
using namespace std;
long long n,m,p,e,a,sol;
int main()
{
freopen("inversmodular.in","r",stdin);
freopen("inversmodular.out","w",stdout);
scanf("%lld%lld",&a,&n);
m=n;
e=1;
for(p=2;p*p<=n;p++)
if(n%p==0)
{
while(n%p==0)
{
n/=p;
e*=p;
}
e/=p;
e*=p-1;
}
if(n>1)e*=n-1;e--;
sol=1;
for(;e;e/=2)
{
if(e%2==1)
sol=(sol*a)%m;
a=(a*a)%m;
}
printf("%lld",sol);
return 0;
}