数论——GCD
来源:互联网 发布:淘宝精品推荐棉拖鞋 编辑:程序博客网 时间:2024/05/16 07:18
ZOJ Problem Set - 3846
题意:
给 N 个数,任取两个数Ai、Aj,求出这两数的GCD,然后用GCD替换这两个数的值。
直至这n个数的值都相等为止,此时输出求GCD的次数,然后按顺序输出每次求GCD的对应的那两个数。
若求GCD的次数超出5*N次时仍未满足停止条件则输出 -1
思路:
只要出现1,就可以将其余的数都变成1,所以,我们从第一个数开始,
GCD(Ai,Ai+1) ,i++;一旦满足GCD(Ai,Ai+1) == 1,便可停止,然后用Ai(或Ai+1)与其他的数做GCD。如此一来求GCD的次数最多不会超过2n-2次。
若i=n-1后仍未出现1,则说明所有数都不会化为相同的数。所以输出 -1
AC代码如下:
#include <iostream>#include <cstring>#include <algorithm>#include "stdio.h"#include<fstream>using namespace std;#define Max_N 100002int N;int num[Max_N];int kgcd(int a, int b) { if (a == 0) return b; if (b == 0) return a; if (!(a & 1) && !(b & 1)) return kgcd(a>>1, b>>1) << 1; else if (!(b & 1)) return kgcd(a, b>>1); else if (!(a & 1)) return kgcd(a>>1, b); else return kgcd(abs(a - b), min(a, b));}int main() { int times = 0; while(scanf("%d",&N)!=EOF) { bool exist_one = false; int tag = 0; times++; for(int i =0 ; i<N; i++) scanf("%d",&num[i]); for(int i =0; i<N-1; i++) { int temp = kgcd(num[i],num[i+1]); if(temp ==1) { exist_one = true; tag = i+1;//取较小的那个数 break; } num[i] = temp,num[i+1] = temp; } printf("Case %d: ",times); if(exist_one) { printf("%d\n",tag+N-2); for(int i = 1; i<=tag; i++) printf("%d %d\n",i ,i+1); for(int i = tag; i>1; i--) printf("%d %d\n",i-1 ,i); for(int i =tag+1; i<N; i++) printf("%d %d\n",i ,i+1); } else { printf("%d",-1); printf("\n"); } printf("\n"); }}
如有错误,还望指出!
转载请注明出处:http://blog.csdn.net/Big_Heart_C
0 0
- 数论——GCD
- 数论(一)——素数,GCD,LCM
- 数论莫比乌斯——bzoj2820YY的GCD
- (hdu 2588 gcd)<数论—欧拉函数>
- 数论、、gcd
- 数论+gcd
- Codeforces Round #290 (Div. 2)D - Fox And Jumping——数论gcd=1
- hdu4497——GCD and LCM(数论&容斥原理or排列组合)
- HDU 1695 GCD 数论
- GCD Again + 数论
- HDU 1695 GCD (数论)
- 1642 - Magical GCD (数论)
- 数论只会GCD。。。
- ZOJ3846 GCD Reduce 数论
- 数论 - hdu5223 GCD
- 【数论】hdu4910Problem about GCD
- 【bzoj2818】【GCD】【数论】
- 简单数论-Gcd
- 单例模式二
- const char*, char const*, char*const的区别
- 黑马程序员-Java学习笔记之IO流(三)
- spring 查漏补缺
- 2015上班工作日子(持续更新)
- 数论——GCD
- 响一声吸费电话 操作简单 月入过万
- Linux程序设计(Linux shell编程七)
- 响一声手机吸费 吸费电话真假 月收入过万
- 真的加值电话 哪有电话吸费 日入600
- Machine Learning(big data)
- 高吸费回拨电话加盟 移动增值业务
- bitset简介
- 吸费手机代理 百分百赚钱 代理加值电话