# | 제출 시각 | 아이디 | 문제 | 언어 | 결과 | 실행 시간 | 메모리 |
---|---|---|---|---|---|---|---|
55323 | 2018-07-07T01:22:23 Z | IvanC | Sirni (COCI17_sirni) | C++17 | 5000 ms | 543020 KB |
#include <bits/stdc++.h> using namespace std; typedef long long ll; typedef pair<int,int> ii; const int MAXN = 1e7 + 1; int pai[MAXN],proximo[MAXN],N,conjuntos; vector<int> ordenado; vector<ii> Kruskal[MAXN]; int find(int x){ int y = x; while(pai[y] != y) y = pai[y]; while(x != y){ int z = pai[x]; pai[x] = y; x = z; } return y; } void join(int x,int y){ x = find(x);y = find(y); if(x == y) return; conjuntos--; if(x > y) swap(x,y); pai[y] = x; } int main(){ scanf("%d",&N); for(int i = 1;i<=N;i++){ int x; scanf("%d",&x); if(pai[x] == x) continue; pai[x] = x; conjuntos++; } for(int i = 1;i<MAXN;i++){ if(pai[i] == 0) continue; ordenado.push_back(i); for(int j = 2*i;j<MAXN;j+=i) if(pai[j] != 0) join(i,j); } int ultimo_visto = ordenado.back(); for(int i = MAXN-1;i>=1;i--){ proximo[i] = ultimo_visto; if(!ordenado.empty() && ordenado.back() == i){ ultimo_visto = i; ordenado.pop_back(); } } if(conjuntos == 1){ printf("0\n"); return 0; } for(int i = 2;i<MAXN;i++){ if(pai[i] == 0) continue; ultimo_visto = -1; for(int j = i;j<MAXN;j+=i){ int candidato = proximo[j]; if(candidato == ultimo_visto) continue; ultimo_visto = candidato; Kruskal[candidato % i].push_back(ii(i,candidato)); } } ll total = 0; for(int w = 0;w<MAXN && conjuntos > 1;w++){ for(ii davez : Kruskal[w]){ int u = davez.first, v = davez.second; if(find(u) != find(v)){ join(u,v); total += w; } } } printf("%lld\n",total); return 0; }
Compilation message
# | 결과 | 실행 시간 | 메모리 | Grader output |
---|---|---|---|---|
1 | Correct | 272 ms | 278228 KB | Output is correct |
2 | Correct | 399 ms | 278760 KB | Output is correct |
3 | Correct | 298 ms | 278760 KB | Output is correct |
# | 결과 | 실행 시간 | 메모리 | Grader output |
---|---|---|---|---|
1 | Correct | 401 ms | 278760 KB | Output is correct |
2 | Correct | 771 ms | 278760 KB | Output is correct |
3 | Correct | 288 ms | 278760 KB | Output is correct |
# | 결과 | 실행 시간 | 메모리 | Grader output |
---|---|---|---|---|
1 | Correct | 293 ms | 278760 KB | Output is correct |
2 | Correct | 306 ms | 278760 KB | Output is correct |
3 | Correct | 287 ms | 278760 KB | Output is correct |
# | 결과 | 실행 시간 | 메모리 | Grader output |
---|---|---|---|---|
1 | Correct | 699 ms | 290168 KB | Output is correct |
2 | Correct | 1520 ms | 315016 KB | Output is correct |
3 | Correct | 733 ms | 315016 KB | Output is correct |
# | 결과 | 실행 시간 | 메모리 | Grader output |
---|---|---|---|---|
1 | Correct | 379 ms | 315016 KB | Output is correct |
2 | Correct | 1253 ms | 315016 KB | Output is correct |
3 | Correct | 789 ms | 315016 KB | Output is correct |
# | 결과 | 실행 시간 | 메모리 | Grader output |
---|---|---|---|---|
1 | Correct | 1154 ms | 315016 KB | Output is correct |
2 | Correct | 1869 ms | 329760 KB | Output is correct |
3 | Correct | 719 ms | 329760 KB | Output is correct |
# | 결과 | 실행 시간 | 메모리 | Grader output |
---|---|---|---|---|
1 | Correct | 692 ms | 329760 KB | Output is correct |
2 | Correct | 1848 ms | 329760 KB | Output is correct |
3 | Correct | 694 ms | 329760 KB | Output is correct |
# | 결과 | 실행 시간 | 메모리 | Grader output |
---|---|---|---|---|
1 | Correct | 586 ms | 329760 KB | Output is correct |
2 | Correct | 4167 ms | 519768 KB | Output is correct |
3 | Correct | 639 ms | 519768 KB | Output is correct |
# | 결과 | 실행 시간 | 메모리 | Grader output |
---|---|---|---|---|
1 | Correct | 595 ms | 519768 KB | Output is correct |
2 | Execution timed out | 5121 ms | 532032 KB | Time limit exceeded |
3 | Halted | 0 ms | 0 KB | - |
# | 결과 | 실행 시간 | 메모리 | Grader output |
---|---|---|---|---|
1 | Correct | 366 ms | 532032 KB | Output is correct |
2 | Execution timed out | 5036 ms | 543020 KB | Time limit exceeded |
3 | Halted | 0 ms | 0 KB | - |