¶
문 번 봤. 는데 른 룰 는 모르.
리 먹 등
X, Y를 는 대를 는 를 는데 .
리 먹 등

X, Y를 는 대를 는 를 는데 .
¶
~cpp
//Euclid Problem/동 2005.04.03
#include <iostream>
using namespace std;
long Eucl(long, long);
long xy[2][2] = {{0,0},{0,1}};
int main(void){
long a, b, gcd;
cin >> a >> b;
bool isSwap = false;
if(a<b){ //a는 무 를 는.
isSwap = true;
swap(a, b);
}
gcd = Eucl(a,b);
if(isSwap==true)
swap(xy[1][0],xy[1][1]);
cout << xy[1][0] << " " << xy[1][1] << " " << gcd <<"\n";
return 0;
}
long Eucl(long a, long b){ //a . a=bq+r 변 r=a-qb a,b
if(a%b == 0)
return b;
long q = (a - a%b)/b;
long tx = xy[0][0], ty = xy[0][1];
xy[0][0] = xy[1][0];
xy[0][1] = xy[1][1];
if(tx==0 && ty==0){//면
xy[1][0] = 1, xy[1][1] = q*-1; // a 는 1.
}
else{
xy[1][0] = xy[0][0]*-1*q+tx; //번 몫q*-1 를 더.
xy[1][1] = xy[0][1]*-1*q+ty;
}
return Eucl(b, a%b);
}










