Cod sursa(job #1398288)

Utilizator ZeBuGgErCasapu Andreas ZeBuGgEr Data 24 martie 2015 09:01:46
Problema Algoritmul lui Euclid extins Scor 100
Compilator cpp Status done
Runda Arhiva educationala Marime 0.67 kb
#include<cstdio>

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()
{
    FILE *fin,*fout;
    fin=fopen("euclid3.in","r");
    fout=fopen("euclid3.out","w");

    int t,a,b,c,d,x,y;
    fscanf(fin,"%d",&t);
    for(int i=1;i<=t;i++)
    {
        fscanf(fin,"%d %d %d",&a,&b,&c);
        d=gcd(a,b,x,y);
        if(c%d!=0)
        {
            fprintf(fout,"0 0\n");
        }
        else
        {
            fprintf(fout,"%d %d\n", x*(c/d),y*(c/d));
        }
    }
}