Cod sursa(job #2050379)
| Utilizator | Data | 28 octombrie 2017 09:39:35 | |
|---|---|---|---|
| Problema | Invers modular | Scor | 10 |
| Compilator | cpp | Status | done |
| Runda | Arhiva educationala | Marime | 0.45 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 (x*(a*a)%N)%N;
}
int main()
{
citire();
fout<<putere(A,N-2);
return 0;
}
