Pagini recente » Cod sursa (job #3328466) | Cod sursa (job #3312650) | Cod sursa (job #3240082) | Cod sursa (job #3334157) | Cod sursa (job #3346407)
#include <iostream>
#include <fstream>
using namespace std;
int main()
{
ifstream fin("inversmodular.in");
ofstream fout("inversmodular.out");
long long x, n, pr, im, i, p;
fin>>x>>n;
i=2;
im=1;
pr=n;
while(i*i<=n){
if(n%i==0){
pr*=i-1;
im*=i;
pr/=im;
while(n%i==0){
n/=i;
}
}
i++;
// cout<<i<<' ';
}
pr-=2;
//cout<<pr-2<<' ';
p=1;
while(pr>0){
if(pr%2==1){
p*=x;
p%=n;
}
x*=x;
x%=n;
pr/=2;
}
fout<<p%n<<'\n';
return 0;
}