Cod sursa(job #2029790)
| Utilizator | Data | 30 septembrie 2017 14:09:15 | |
|---|---|---|---|
| Problema | Invers modular | Scor | 60 |
| Compilator | cpp | Status | done |
| Runda | Arhiva educationala | Marime | 0.57 kb |
#include <iostream>
#include <cstdio>
using namespace std;
int mod;
long long logpow(long long base, long long p)
{
int b=32;
long long A=1;
while(b>=0)
{
if(p&1LL<<b)
{
A=(A*A)%mod;
A=(A*base)%mod;
}
else
{
A=(A*A)%mod;
}
b--;
}
return A;
}
int main()
{
freopen("inversmodular.in","r",stdin);
freopen("inversmodular.out","w",stdout);
int a,b,i;
cin>>a>>b;
mod=b;
cout<<logpow(a,b-2)%b;
return 0;
}
