Cod sursa(job #2050723)
Utilizator | Data | 28 octombrie 2017 11:08:09 | |
---|---|---|---|
Problema | Invers modular | Scor | 60 |
Compilator | cpp | Status | done |
Runda | Arhiva educationala | Marime | 0.5 kb |
#include <iostream>
#include <fstream>
#define ll long long
using namespace std;
ifstream fin("inversmodular.in");
ofstream fout("inversmodular.out");
ll A,N;
void citire()
{
fin>>A>>N;
}
ll putere(ll x,ll n)
{
ll a;
if(!n) return 1;
if(n==1) return x;
a=putere(x,n/2);
if(n%2==0) return (a*a)%N;
else return ((a*a)%N*x)%N;
}
int main()
{
citire();
if(putere(A,N-2)<0) fout<<putere(A,N-2)+N;
else fout<<putere(A,N-2);
return 0;
}