Cod sursa(job #153139)

Utilizator razvi9Jurca Razvan razvi9 Data 10 martie 2008 10:29:07
Problema Algoritmul lui Euclid extins Scor 70
Compilator cpp Status done
Runda Arhiva educationala Marime 0.79 kb
#include<fstream>
using namespace std;
long long a,b,x,y,d,c,t;
void euclid(long long a,long long b,long long &d,long long &x,long long &y)
{
	if(b==0){
		x=1;
		y=1;
		d=a;
		return;}
	long long x0,y0;
	euclid(b,a%b,d,x0,y0);
	x=y0;
	y=x0-(a/b)*y0;
}
int main()
{
	ifstream f("euclid3.in");
	ofstream g("euclid3.out");
	f>>t;
	for(;t;t--){
		f>>a>>b>>c;
		euclid(a,b,d,x,y);
		int k=b/d,l=a/d;
		while(x<-2000000000) x+=k,y-=l;
		while(x>2000000000) x-=k,y+=l;
		while(y<-2000000000) x-=k,y+=l;
		while(y>2000000000) x+=k,y-=l;
		if(c%d==0){
			x=x*c/d;
			y=y*c/d;
			while(x<-2000000000) x+=k,y-=l;
			while(x>2000000000) x-=k,y+=l;
			while(y<-2000000000) x-=k,y+=l;
			while(y>2000000000) x+=k,y-=l;
			g<<x<<" "<<y<<endl;}
		else
			g<<0<<" "<<0<<endl;}
	g.close();
}