Pagini recente » Cod sursa (job #2388112) | Cod sursa (job #1984862) | Cod sursa (job #2605690) | Cod sursa (job #1400646) | Cod sursa (job #1348999)
#include <iostream>
#include <fstream>
#include <cmath>
#define ull unsigned long long
using namespace std;
ull N,a,n,b=1;
ull phi(ull x)
{
ull i,y=x;
for(i=2;i*i<=x;i++)
{
if(x%i==0)
{
y*=(x-1)/x;
while(x%i==0)
x/=i;
}
}
if(x!=1) y*=(x-1)/x;
return y;
}
int main()
{
ull i,j=1;
FILE *f=fopen("inversmodular.in","r");
FILE *g=fopen("inversmodular.out","w");
fscanf(f,"%lld %lld",&a,&n);
i=phi(n)-1;
while(i)
{
if(i>>1<<1!=i)
j=(j*a)%n;
a*=a;
a%=n;
i/=2;
}
j%=n;
fprintf(g,"%lld\n",j);
return 0;
}