Cod sursa(job #628704)
| Utilizator | Data | 1 noiembrie 2011 22:18:44 | |
|---|---|---|---|
| Problema | Algoritmul lui Euclid extins | Scor | 100 |
| Compilator | cpp | Status | done |
| Runda | Arhiva educationala | Marime | 0.51 kb |
#include <cstdio>
inline int gcd(int a,int b,int &x,int &y)
{
if(b==0)
{
x = 1 , y = 0;
return a;
}
int x0 , y0 , d;
d = gcd(b,a%b,x0,y0);
x = y0;
y = x0 - (a/b)*y0;
return d;
}
int main()
{
int T , A , B , C;
freopen("euclid3.in","r",stdin);
freopen("euclid3.out","w",stdout);
scanf("%d",&T);
for(;T;T--)
{
scanf("%d %d %d",&A,&B,&C);
int D , X , Y;
D = gcd(A,B,X,Y);
if(C%D) printf("0 0\n");
else
printf("%d %d\n",X*(C/D),Y*(C/D));
}
return 0;
}
