lzh

刘政
posts - 17, comments - 1, trackbacks - 0, articles - 1

最大公约数问题

Posted on 2011-04-25 22:34 lzh525 阅读(372) 评论(0)  编辑 收藏 引用 所属分类: ACM解题报告
#include using namespace std; int gcd(int x,int y) {//欧几里得:辗转相除法 if(x>1,y>>1) //若x偶,y奇, 则f(x,y)=f(x>>1,y) //若x奇,y偶, 则f(x,y)=f(x,y>>1) //若x,y都为奇数,f(x,y)=f(y,x-y),那么在f(x,y)=f(y,x-y)之后(x-y)是一个偶数,下一步会有除以2的操作,所以最坏情况下的时间复杂度O(log2(max(x,y))) int f2(int x,int y) { if(x>1,y>>1)<<1); else return f2(x>>1,y); } else { if(y%2==0) return f2(x,y>>2); else return f2(y,x-y); } } } int main() { int m,n; while(cin>>m>>n) { printf("%d与%d的最大公约数为:\n",m,n); //cout<

只有注册用户登录后才能发表评论。
网站导航: 博客园   IT新闻   BlogJava   知识库   博问   管理