Pagini recente » Cod sursa (job #2096482) | Cod sursa (job #1942188) | Cod sursa (job #2432677) | Cod sursa (job #401152) | Cod sursa (job #2537967)
#include <iostream>
#include <fstream>
using namespace std;
long long inversModular(long long A, long long P, long long MOD)
{
int result = 1;
while (P > 0)
if (P % 2 == 0)
A = (A * A) % MOD, P /= 2;
else
result = (result * A) % MOD, --P;
return result;
}
int main()
{
ifstream fi("inversmodular.in");
ofstream fo("inversmodular.out");
long long A, N; fi >> A >> N;
// calculam A ^ (N - 2) % N
fo << inversModular(A, N - 2, N);
return 0;
}