Coprime Sequence(前后缀最大公约数)
2017-05-10 17:30
323 查看
链接:http://acm.hdu.edu.cn/showproblem.php?pid=6025
题意:给出一个序列,这个序列的最大公约数为1,求去掉一个数之后的最大公约数
思路:果然就是数学学得不好,补题的时候知道是由前缀后最大公约数来求。具体就是:
pre[i]是到i为止的前面的数的最大公约数
nex[i]是从i开始到最后的数的最大公约数
ans再找他们之间的最大公约数
代码:
题意:给出一个序列,这个序列的最大公约数为1,求去掉一个数之后的最大公约数
思路:果然就是数学学得不好,补题的时候知道是由前缀后最大公约数来求。具体就是:
pre[i]是到i为止的前面的数的最大公约数
nex[i]是从i开始到最后的数的最大公约数
ans再找他们之间的最大公约数
代码:
#include <iostream> #include <cstring> #include <cstdio> #include <cmath> #include <algorithm> using namespace std; int a[100010]; int pre[100010],nex[100010]; int gcd(int a, int b) { return b == 0 ?a:gcd(b,a%b); } int main() { int t; cin >> t; while(t--) { int n; cin >> n; for(int i=0; i<n; i++) cin >> a[i]; sort(a,a+n); memset(pre, 0 ,sizeof pre); memset(nex, 0 ,sizeof nex); pre[0] = a[0]; nex[n-1] = a[n-1]; for(int i=1; i<n; i++) { pre[i] = gcd(pre[i-1],a[i]); } for(int i=n-2; i>=0; i--) { nex[i] = gcd(nex[i+1],a[i]); } int ans = max(nex[1],pre[n-2]); for(int i=1; i<n-1; i++) { if(ans < gcd(pre[i-1],nex[i+1])) ans = gcd(pre[i-1],nex[i+1]); } cout << ans << endl; } return 0; }
相关文章推荐
- HDU6025 Coprime Sequence —— 前缀和 & 后缀和
- HDU6025 Coprime Sequence【前缀GCD+后缀GCD】
- 2017女生赛 1003 Coprime Sequence【前缀后缀维护】
- HDU 6025 Coprime Sequence(前缀后缀GCD问题)
- HDU6025 Coprime Sequence (前缀后缀处理)
- HDU 6025 Coprime Sequence (前后缀+GCD)
- HDU 6025 Coprime Sequence 前缀gcd + 后缀gcd
- HDU6025 Coprime Sequence【前缀GCD+后缀GCD】
- HDU - 6025 Coprime Sequence(给出一行数,去掉其中一个数,求这行数的最大的最大公约数(gcd)))
- hdu 6025 Coprime Sequence (前后缀GCD)
- HDU - 6025 Coprime Sequence(前缀,后缀,gcd)
- HDU 6025 Coprime Sequence
- HDU6025-Coprime Sequence-简单数学
- HDU6025-Coprime Sequence
- HDU - 6025 Coprime Sequence
- HDU 6025 Coprime Sequence
- (HDU 6025 女生专场)Coprime Sequence 水题
- Coprime Sequence HDU - 6025
- Coprime Sequence HDU - 6025
- Coprime Sequence