Cod sursa(job #1889108)

Utilizator dan.marculetFII MarculetDan dan.marculet Data 22 februarie 2017 16:17:34
Problema Algoritmul lui Euclid extins Scor 50
Compilator cpp Status done
Runda Arhiva educationala Marime 0.7 kb
#include <cstdio>
using namespace std;

auto fin = fopen("euclid3.in", "r");
auto fout = fopen("euclid3.out", "w");

int euclid(int a, int b, int &x, int &y) {
    if (b == 0) {
        x = 1;
        y = 0;
        return a;
    }
    int xprev, yprev;
    int d = euclid(b, a % b, xprev, yprev);
    x = yprev;
    y = xprev - (a / b) * yprev;
    return d;
}

int main() {
    int t;
    fscanf(fin, "%d", &t);
    while (t--) {
        int x, y, a, b, c, d;
        fscanf(fin, "%d %d %d", &a, &b, &c);
        d = euclid(a, b, x, y);
        if (c % d)
            fprintf(fout, "0 0\n");
        else
            fprintf(fout, "%d %d\n", x * c / d, y * c / d);
    }
    return 0;
}