This submission is migrated from previous version of oj.uz, which used different machine for grading. This submission may have different result if resubmitted.
#include <bits/stdc++.h>
using namespace std;
const int N = 5e5 + 1, MOD = 998244353,MAX = 1e7 + 1;
typedef long long ll;
int n,a[N],p[MAX];
vector<ll> b;
vector<pair<int,int>> g[MAX];
int get(int v){
if(p[v] == v) return v;
return p[v] = get(p[v]);
}
void merge(int v,int u){
v = get(v);
u = get(u);
p[v] = u;
}
void add(int x){
for(int i = 0;true;i++){
if(i * x > b.back()) break;
int it = lower_bound(b.begin(),b.end(),x * i) - b.begin();
// if(b[it] == x) it++;
if(it < (int)b.size()){
int val = min(b[it] % x,x % b[it]);
// cout << val << ' ' << x << ' ' << b[it] << '\n';
g[val].push_back({x,b[it]});
}
}
}
void test(){
cin >> n;
for(int i = 1;i <= n;i++){
cin >> a[i];
}
for(int i = 1;i < MAX;i++){
p[i] = i;
}
sort(a + 1,a + n + 1);
for(int i = 1;i <= n;i++){
if(a[i] != a[i - 1]){
b.push_back(a[i]);
}
}
for(auto i:b){
add(i);
}
ll ans = 0;
for(int i = 0;i < MAX;i++){
for(auto [x,y]:g[i]){
if(get(x) != get(y)){
ans += i;
merge(x,y);
}
}
}
cout << ans;
}
int main()
{
ios_base::sync_with_stdio(0);
cin.tie(0);
int T = 1; // cin >> T;
while (T--)
test();
}
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |