Cod sursa(job #581619)
| Utilizator | Data | 14 aprilie 2011 13:28:28 | |
|---|---|---|---|
| Problema | Algoritmul lui Euclid extins | Scor | 100 |
| Compilator | cpp | Status | done |
| Runda | Arhiva educationala | Marime | 0.62 kb |
#include <fstream>
#include <cstdlib>
using namespace std;
inline void gcd( int a, int b, int& x, int& y, int& d )
{
if( 0 == b )
{
x=1;
y=0;
d=a;
return;
}
int x0, y0;
gcd( b, a%b, x0, y0, d );
x=y0;
y=x0-(a/b)*y0;
}
int main(void)
{
int T, a, b, c, d, x, y;
ifstream in( "euclid3.in" );
ofstream out( "euclid3.out" );
for( in>>T; T; --T )
{
in>>a>>b>>c;
gcd( a, b, x, y, d );
if( c%d )
out<<"0 0\n";
else c/=d, out<<(x*c)<<' '<<(y*c)<<'\n';
}
return EXIT_SUCCESS;
}
