Pagini recente » Cod sursa (job #3307657) | Cod sursa (job #3322896) | Cod sursa (job #3312409) | Cod sursa (job #2897261) | Cod sursa (job #3346773)
#include <iostream>
#include <fstream>
using namespace std;
ifstream fin("inversmodular.in");
ofstream fout("inversmodular.out");
int a, n, nr=0;
int pow(int x, int n){
int rez=1, left=x;
while(n>0){
if(n%2==1){
rez=left*rez;
n--;
}
n=n/2;
left=left*left;
}
return rez;
}
int cmmdc(int x, int y){
while(y!=0 and x!=0){
int r=x%y;
x=y;
y=r;
}
return x;
}
int main()
{
fin>>a>>n;
for(int i=1;i<n;i++)
if(cmmdc(i, n)==1) nr++;
fout<<pow(a, nr-1)%n;
return 0;
}