Cod sursa(job #1125010)

Utilizator muresan_bogdanMuresan Bogdan muresan_bogdan Data 26 februarie 2014 15:06:11
Problema Algoritmul lui Euclid extins Scor 100
Compilator cpp Status done
Runda Arhiva educationala Marime 0.64 kb
#include<iostream>
#include<fstream>
using namespace std;

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

int t, a, b, c, d;

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

int main() {
    fin >> t;
    for(int i = 0; i < t; i++) {
        fin >> a >> b >> c;
        int x, y;
        d = cmmdc(a, b, x, y);
        if(c%d) {
            fout << "0 0\n";
        }else{
            fout << x*(c/d) << ' ' << y*(c/d) << '\n';
        }
    }
}