Cod sursa(job #2605072)

Utilizator razvan1403razvan razvan1403 Data 24 aprilie 2020 12:56:26
Problema Algoritmul lui Euclid extins Scor 100
Compilator cpp-64 Status done
Runda Arhiva educationala Marime 0.79 kb
#include<bits/stdc++.h>
#include<assert.h>

using namespace std;

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

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;
}
void solve()
{
    int a,b,c;
    fin>>a>>b>>c;
    assert(-1000000000 <= a && a <= 1000000000);
    assert(-1000000000 <= b && b <= 1000000000);
    assert(-2000000000 <= c && c <= 2000000000 && c != 0);
    int d,x,y;
    d=gcd(a,b,x,y);
    if(c%d)
        fout<<"0 0"<<'\n';
    else fout<<x*(c/d)<<" "<<y*(c/d)<<'\n';
}

int main()
{
    int T;
    fin>>T;
    assert(1<= T && T <=100);
    while(T--)
    {
        solve();
    }
    fin.close();
    fout.close();
    return 0;
}