#include <bits/stdc++.h>
using namespace std;
const int mN = 1e5 + 5, mP = 1e7 + 5;
int n, mx, ub[mP], par[mN], sz[mN]; long long ans; vector<int> A; vector<pair<int, int>> edg[mP];
int get(int i){
return (i == par[i]) ? i : par[i] = get(par[i]);
}
void merge(int a, int b, int w){
a = get(a); b = get(b); if (a == b) return;
if (a > b) swap(a, b);
par[a] = b; sz[b] += sz[a]; ans += w;
}
int main(){
cin >> n; A.resize(n);
for (int &i : A) cin >> i;
sort(A.begin(), A.end()); A.erase(unique(A.begin(), A.end()), A.end());
n = A.size(); mx = A.back(); iota(par, par + n, 0); fill(sz, sz + n, 1);
for (int i = 0; i < n; i++) ub[A[i]] = i;
for (int i = mx, cur = n - 1; i >= 0; i--) (ub[i]) ? cur = ub[i] : ub[i] = cur;
for (int i = 0; i < n - 1; i++)
for (int x = A[i]; x <= mx; x += A[i]){
int j = ub[x + (x == A[i])];
if (A[j] < x + A[i])
edg[A[j] % x].push_back({i, j});
}
for (int i = 0; i < mx; i++)
for (auto edge : edg[i])
merge(edge.first, edge.second, i);
cout<<ans<<endl;
}
# |
결과 |
실행 시간 |
메모리 |
Grader output |
1 |
Correct |
173 ms |
274372 KB |
Output is correct |
2 |
Correct |
219 ms |
276592 KB |
Output is correct |
3 |
Correct |
174 ms |
274372 KB |
Output is correct |
# |
결과 |
실행 시간 |
메모리 |
Grader output |
1 |
Correct |
130 ms |
235280 KB |
Output is correct |
2 |
Correct |
479 ms |
274896 KB |
Output is correct |
3 |
Correct |
174 ms |
274500 KB |
Output is correct |
# |
결과 |
실행 시간 |
메모리 |
Grader output |
1 |
Correct |
174 ms |
274372 KB |
Output is correct |
2 |
Correct |
180 ms |
274132 KB |
Output is correct |
3 |
Correct |
177 ms |
274552 KB |
Output is correct |
# |
결과 |
실행 시간 |
메모리 |
Grader output |
1 |
Correct |
226 ms |
249592 KB |
Output is correct |
2 |
Correct |
341 ms |
276924 KB |
Output is correct |
3 |
Correct |
241 ms |
254772 KB |
Output is correct |
# |
결과 |
실행 시간 |
메모리 |
Grader output |
1 |
Correct |
145 ms |
240824 KB |
Output is correct |
2 |
Correct |
287 ms |
261356 KB |
Output is correct |
3 |
Correct |
213 ms |
247776 KB |
Output is correct |
# |
결과 |
실행 시간 |
메모리 |
Grader output |
1 |
Correct |
292 ms |
261596 KB |
Output is correct |
2 |
Correct |
397 ms |
291744 KB |
Output is correct |
3 |
Correct |
237 ms |
253408 KB |
Output is correct |
# |
결과 |
실행 시간 |
메모리 |
Grader output |
1 |
Correct |
158 ms |
239480 KB |
Output is correct |
2 |
Correct |
380 ms |
285836 KB |
Output is correct |
3 |
Correct |
230 ms |
252860 KB |
Output is correct |
# |
결과 |
실행 시간 |
메모리 |
Grader output |
1 |
Correct |
351 ms |
287296 KB |
Output is correct |
2 |
Correct |
1716 ms |
484228 KB |
Output is correct |
3 |
Correct |
369 ms |
289860 KB |
Output is correct |
# |
결과 |
실행 시간 |
메모리 |
Grader output |
1 |
Correct |
359 ms |
287288 KB |
Output is correct |
2 |
Correct |
3493 ms |
575044 KB |
Output is correct |
3 |
Correct |
412 ms |
294472 KB |
Output is correct |
# |
결과 |
실행 시간 |
메모리 |
Grader output |
1 |
Correct |
207 ms |
276636 KB |
Output is correct |
2 |
Correct |
3909 ms |
569580 KB |
Output is correct |
3 |
Correct |
249 ms |
254900 KB |
Output is correct |