Pagini recente » Cod sursa (job #2480559) | Cod sursa (job #1933534) | Cod sursa (job #2263297) | Diferente pentru implica-te/arhiva-educationala intre reviziile 45 si 44 | Cod sursa (job #2050723)
#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;
}