Cod sursa(job #1495587)

Utilizator PaulCbnCiobanu Paul PaulCbn Data 3 octombrie 2015 11:46:33
Problema Algoritmul lui Euclid extins Scor 100
Compilator cpp Status done
Runda Arhiva educationala Marime 0.78 kb
#include <iostream>
#include <cstdio>
using namespace std;

int euclid(int a, int b,int &x,int &y)
{
    if(b==0)
        return a;
    int r = a%b;
    int cmmdc = euclid(b,r,x,y);
    int c = a/b;
    int x_prec=x,y_prec=y;
    x = y_prec;
    y = x_prec - c*y_prec;
    return cmmdc;

}

void solve(int a,int b,int c)
{
    int x=1,y=0;
    int d = euclid(a,b,x,y);
    if(c%d)
    {
        printf("0 0\n");
        return;
    }
    int div = c / d;
    printf("%d %d\n",x*div,y*div);

}

int main()
{
    freopen("euclid3.in","r",stdin);
    freopen("euclid3.out","w",stdout);
    int n;
    scanf("%d",&n);
    for(int i =1 ;i<=n ;i++)
    {
        int a,b,c;
        scanf("%d%d%d",&a,&b,&c);
        solve(a,b,c);
    }

    return 0;
}