Cod sursa(job #2428584)
| Utilizator | Data | 5 iunie 2019 20:53:59 | |
|---|---|---|---|
| Problema | Invers modular | Scor | 60 |
| Compilator | cpp-64 | Status | done |
| Runda | Arhiva educationala | Marime | 0.47 kb |
#include <iostream>
#include <fstream>
using namespace std;
ifstream f("inversmodular.in");
ofstream g("inversmodular.out");
int64_t n, MOD, fast_exp(int64_t, int64_t);
int main()
{
f >> n >> MOD;
g << fast_exp(n, MOD - 2) ;
return 0;
}
int64_t fast_exp(int64_t n, int64_t e)
{
if(e == 0)
return 1;
int64_t r = fast_exp(n, e / 2);
r = (1LL * r * r) % MOD;
if(e % 2 == 1)
r = (1LL * r * n) % MOD;
return r;
}
