Cod sursa(job #2171452)

Utilizator puzzleFlutur Vasile puzzle Data 15 martie 2018 12:24:43
Problema Algoritmul lui Euclid extins Scor 100
Compilator cpp Status done
Runda Arhiva educationala Marime 0.62 kb
#include <fstream>

using namespace std;

ifstream in("euclid3.in");
ofstream out("euclid3.out");

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;
    in>>T;
    int A, B, X, Y, C;
    while(T)
    {
        in>>A>>B>>C;
        int D = gcd(A,B,X,Y);
        if(C%D==0)
            out<<X*(C/D)<<" "<<Y*(C/D);
        else
            out<<0<<" "<<0;
        out<<'\n';
        T--;
    }
}