#include<iostream> #include<cstring> using namespace std; char s1[2005],s2[2005]; struct node{ int len; int w[2005]; }; node Tr(char s[]) { int m=strlen(s); node n; n.len=m; int k=0; for(int i=m-1;i>=0;i--) { n.w[k]=s[i]-'0'; k++; } return n; } node div(node a) //二进制数右移一位 { int m=a.len; for(int i=0;i<m-1;i++) { a.w[i]=a.w[i+1]; } a.len--; return a; } node Minus(node a,node b) { node c; int borrow=0,i; c.len=a.len; for(i=0;i<b.len;i++) { int tmp=a.w[i]-b.w[i]-borrow; if(tmp>=0) { borrow=0,c.w[i]=tmp;} else { borrow=1,c.w[i]=tmp+2;} //向前借一位 } while(i<a.len) { int tmp=a.w[i]-borrow; if(tmp>=0) { borrow=0,c.w[i]=tmp;} else { borrow=1,c.w[i]=tmp+2;} i++; } i--;//i=a.len-1 while(i>=0&&c.w[i]==0) { i--; c.len--; } return c; } void gcd(node a,node b) //a>b { int cnt=0; while(a.len&&b.len) { if(a.w[0]==0) //a为偶数 { if(b.w[0]==0) //b为偶数 { a=div(a); b=div(b); cnt++; } else a=div(a); } else { if(b.w[0]==0) b=div(b); else { a=Minus(a,b); } } } if(a.len) { for(int i=a.len-1;i>=0;i--) cout<<a.w[i]; } else { for(int i=b.len-1;i>=0;i--) cout<<b.w[i]; } while(cnt--) cout<<'0'; //乘以2相当于在末尾添加一个0 cout<<endl; } int main() { while(cin>>s1>>s2) { node a,b; if(strcmp(s1,s2)>=0) { a=Tr(s1); b=Tr(s2); } else { a=Tr(s2); b=Tr(s1); } gcd(a,b);//保证a>=b } return 0; }