Cod sursa(job #1890452)

Utilizator RigonsRadu Molnar Rigons Data 23 februarie 2017 11:56:08
Problema Algoritmul lui Euclid extins Scor 100
Compilator cpp Status done
Runda Arhiva educationala Marime 0.84 kb
#include <iostream>
#include <fstream>
#include <cassert>
using namespace std;
ifstream fin("euclid3.in");
ofstream fout("euclid3.out");
int euclidext(int a,int b,int &x, int &y)
{
    if(b==0)
    {
        x=1;
        y=0;
        return a;
    }
        int d,x0,y0;
        d=euclidext(b,a%b,x0,y0);
        x=y0;
        y=x0-(a/b)*y0;
        return d;


}
int main()
{
    int n;
    fin>>n;
    for(int i=1;i<=n;i++)
    {
        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=euclidext(a,b,x,y);
        if(c%d!=0)
            fout<<0<<" "<<0<<'\n';
        else fout<<x*(c/d)<<" "<<y*(c/d)<<'\n';
    }
    return 0;
}