Cod sursa(job #3245364)

Utilizator AndreiSorin26012001Cirpici Andrei Sorin AndreiSorin26012001 Data 28 septembrie 2024 17:52:58
Problema Algoritmul lui Euclid extins Scor 100
Compilator cpp-64 Status done
Runda Arhiva educationala Marime 0.64 kb
#include <fstream>

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()
{
    std::ifstream in("euclid3.in");
    std::ofstream out("euclid3.out");

    int n; in>>n;
    for(int i = 0; i < n; i++)
    {
        int a, b, c; in>>a>>b>>c;

        int x, y, d;

        d = gcd(a, b, x, y);
        if(c % d == 0)
            out<<x * (c / d)<<" "<<y * (c / d)<<"\n";
        else
            out<<"0 0 \n";
    }

    in.close();
    out.close();
    return 0;
}