Cod sursa(job #2265286)
Utilizator | Octavian Petrut Petru00 | Data | 20 octombrie 2018 21:50:52 |
---|---|---|---|
Problema | Algoritmul lui Euclid extins | Scor | 100 |
Compilator | cpp-64 | Status | done |
Runda | Arhiva educationala | Marime | 0.63 kb |
#include <fstream>
using namespace std;
ifstream fin("euclid3.in");
ofstream fout("euclid3.out");
int cmmdc(int a, int b,int &x,int &y) //ALGORITMUL LUI EUCLID EXTINS
{
if(b==0)
{
x=1;
y=0;
return a;
}
int d,aux;
d=cmmdc(b,a%b,x,y);
aux=y;
y=x-y*(a/b);
x=aux;
return d;
}
int main()
{
int n,a,b,c,d,x,y;
fin>>n;
while(n--)
{
fin>>a>>b>>c;
d=cmmdc(a,b,x,y);
if(c%d==0)
{
x=x*(c/d);
y=y*(c/d);
}
else x=y=0;
fout<<x<<" "<<y<<'\n';
}
return 0;
}