求两个二进制数的最大公约数
来源:互联网 发布:魅族网络打印 编辑:程序博客网 时间:2024/05/22 00:38
#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;}
0 0
- 求两个二进制数的最大公约数
- 求两个数的最大公约数
- 求两个数的最大公约数
- 求两个数的最大公约数
- 求两个数的最大公约数
- 求两个数的最大公约数
- 求两个数的最大公约数
- 求两个数的最大公约数
- 求两个数的最大公约数
- 求两个数的最大公约数
- 求两个数的最大公约数
- 求两个数的最大公约数
- 求两个数的最大公约数
- 求两个数的最大公约数
- 求两个数的最大公约数
- 求两个数的最大公约数
- 求两个数的最大公约数
- 求两个数的最大公约数
- UVa 1428 Ping pong (树状数组)
- PerconaXtrabackup 压缩备份集
- iptables学习
- SpringIOC--初始化源码解析
- HDOJ 2066 一个人的旅行(最短路)
- 求两个二进制数的最大公约数
- 初窥 CATransform3D 文档解读
- 计算机网络问题总结
- itoo在线编辑学习——nignx
- POJ 3687 Labeling Balls
- 前台网页规划
- Win8.1 远程桌面多用户登录方法
- Android 6.0 changes 上
- 判断一个变量是否属于数组类型