Submission #1085109

#TimeUsernameProblemLanguageResultExecution timeMemory
1085109fryingducSirni (COCI17_sirni)C++17
0 / 140
185 ms239768 KiB
#include "bits/stdc++.h" using namespace std; #ifdef duc_debug #include "bits/debug.h" #else #define debug(...) #endif const int maxn = 1e5 + 5; const int N = 1e7 + 7; int n, a[maxn]; vector<int> value[N]; int lab[maxn]; int find(int u) { return lab[u] < 0 ? u : lab[u] = find(lab[u]); } bool is_joined(int u, int v) { u = find(u), v = find(v); if(u == v) return 1; if(lab[u] > lab[v]) swap(u, v); lab[u] += lab[v]; lab[v] = u; return 0; } void solve() { cin >> n; for(int i = 1; i <= n; ++i) { cin >> a[i]; lab[i] = -1; value[a[i]].push_back(i); } sort(a + 1, a + n + 1); int rem = 0; long long ans = 0; while(1) { for(int i = 1; i <= n; ++i) { for(int j = a[i] + rem; j <= a[n]; j += a[i]) { if(value[j].empty()) continue; for(auto pos:value[j]) { if(!is_joined(i, pos)) { ans += rem; } } } } bool flag = 1; for(int i = 2; i <= n; ++i) { if(find(i) != find(1)) { flag = 0; break; } } if(flag) { cout << ans; return; } ++rem; } } signed main() { ios_base::sync_with_stdio(0); cin.tie(0); solve(); return 0; }
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...