Pagini recente » Cod sursa (job #1037974) | Cod sursa (job #936415) | Cod sursa (job #1743712) | Cod sursa (job #996041) | Cod sursa (job #2586481)
#include <iostream>
#include <fstream>
#include <algorithm>
#include <utility>
#include <cstring>
using namespace std;
ifstream in("inversmodular.in");
ofstream out("inversmodular.out");
#define ull long long int
ull egcd(ull a, ull b, ull *x, ull *y)
{
if(b ==0)
{
*x=1;
*y=0;
return a;
}
ull x0,y0,d;
d = egcd(b,a%b,&x0,&y0);
*x = y0;
*y = x0 - (a/b)*y0;
return d;
}
int main ( )
{
ull a,n,x,y,d;
in>>a>>n;
d = egcd(a,n,&x,&y);
while(x<0) x+=n;
out<<x;
return 0;
}