#include<bits/stdc++.h> using namespace std; int gcd(int a, int b) { if (b == 0)return a; else return gcd(b, a%b); } int flag[1000]; int getFather(int x) { if (flag[x] == -1)return x; else { int tmp = getFather(flag[x]); flag[x] = tmp; return tmp; } } int main() { int n; cin >> n; vector<int>sugar(n); vector<int>nums(n); for (int i = 0; i < n; i++) { cin >> sugar[i]; flag[i] = -1; nums[i] = 1; } for (int i = 0; i < n; i++) { for (int j = 0; j <= i; j++) { if (gcd(sugar[i], sugar[j]) > 1) { int a = getFather(i); int b = getFather(j); if (a != b) { flag[a] = b; nums[b] += nums[a]; } } } } int res = 0; for (int i = 0; i < n; i++) res = max(res, nums[i]); cout << res << endl; return 0; } 我用并查集做的,也是70%
点赞 2

相关推荐

还是想躺平了:那就认清呗,按他们说的读研读博,爆着家里米然后边玩边学,考不上就再考一年反正花的家里钱,等他们被啃得受不了了来怪你,就说当年都要找到工作了被谁搞没了
点赞 评论 收藏
分享
02-26 13:56
已编辑
重庆财经学院 Java
King987:你有实习经历,但是写的也太简单了,这肯定是不行的,你主要要包装实习经历这一块,看我的作品,你自己包装一下吧,或者发我,我给你出一期作品
点赞 评论 收藏
分享
牛客网
牛客网在线编程
牛客网题解
牛客企业服务