Pagini recente » Cod sursa (job #2237581) | Cod sursa (job #3284374) | Cod sursa (job #3152873) | Cod sursa (job #2966320) | Cod sursa (job #2204510)
#include<fstream>
using namespace std;
ifstream f("inversmodular.in");
ofstream g("inversmodular.out");
long long int p(long long int a, long long int b){
if(b==0) return 1;
if(b==1) return a;
long long int t=p(a, b/2);
return t*t*p(a, b%2);
}
int a, n, v[1000];
int main(){
f>>a>>n;
v[1]=1;
for(int i=2;i<=n;i++){
v[i]=i-1;
}
for(int i=2;i<=n;i++){
for(int j=i+i;j<=n;j+=i){
v[j]-=v[i];
}
}
g<<p(a, v[n]-1)%n;
}