Pagini recente » Diferente pentru problema/euclid4 intre reviziile 7 si 2 | Diferente pentru problema/role intre reviziile 5 si 6 | Cod sursa (job #1276608) | Cod sursa (job #999874) | Cod sursa (job #2989666)
#include <fstream>
using namespace std;
ifstream f ("inversmodular.in");
ofstream g ("inversmodular.out");
long long a, n;
long long exp(long long a, int x){
long long p = 1;
while(x){
if(x % 2 == 1){
p = (p * a) % n;
}
a = (a * a) % n;
x /= 2;
}
return p % n;
}
int main()
{
f >> a >> n;
g << exp(a, n - 2);
return 0;
}