Cod sursa(job #1098849)

Utilizator bullseYeIacob Sergiu bullseYe Data 5 februarie 2014 11:58:01
Problema Algoritmul lui Euclid extins Scor 0
Compilator cpp Status done
Runda Arhiva educationala Marime 0.78 kb
#include <fstream>
using namespace std;
ifstream fin("euclid3.in");
ofstream fout("euclid3.out");
int t, a, b, c;
int x, y;
void euclid (int, int, int&, int&);
int cmmdc (int a, int b);
int main()
{
    int i, val;
    fin>>t;
    for (i=1; i<=t; ++i)
    {
        x=y=0;
        fin>>a>>b>>c;
        val=cmmdc(a, b);
        if (c%val!=0)
            fout<<"0 0\n";
            else
            {
            a*=c/val; b*=c/val;
            euclid (a, b, x, y);
            fout<<x<<" "<<y<<"\n";
            }
    }
}

void euclid (int a, int b, int &x, int &y)
{
    if (!b) {x=1; y=0; return;}
    int x0, y0;
    euclid(b, a%b, x0, y0);
    x=y0;
    y=x0-y0*(a/b);
    return;
}

int cmmdc(int a, int b)
{
    if (!b) return a;
    cmmdc (b, a%b);
}