Cod sursa(job #2029714)
| Utilizator | Data | 30 septembrie 2017 12:51:45 | |
|---|---|---|---|
| Problema | Invers modular | Scor | 40 |
| Compilator | cpp | Status | done |
| Runda | Arhiva educationala | Marime | 0.46 kb |
#include <fstream>
using namespace std;
ifstream cin("inversmodular.in");
ofstream cout("inversmodular.out");
long long expow(long long a,long long b,long long mod)
{
long long sol=1;
for(int i=0;(1<<i)<=b;i++)
{
if(b&(1<<i))
sol=sol*a%mod;
a=a*a%mod;
}
return sol;
}
int main()
{
ios_base::sync_with_stdio(0);
long long a,n,y;
cin>>a>>n;
y=expow(a,n-2,n);
cout<<y;
return 0;
}
