이 제출은 이전 버전의 oj.uz에서 채점하였습니다. 현재는 제출 당시와는 다른 서버에서 채점을 하기 때문에, 다시 제출하면 결과가 달라질 수도 있습니다.
#include "game.h"
#define N 1501
int p[N], sz[N];
int cnt[N][N];
int find(int x){
return (x == p[x] ? x : p[x] = find(p[x]));
}
void initialize(int n){
for(int i = 0; i < n; i++) p[i] = i, sz[i] = 1;
}
int hasEdge(int u, int v) {
v = find(v);
u = find(u);
cnt[v][u]++;
cnt[u][v]++;
if(cnt[v][u] != sz[v] * sz[u]) return 0;
if(v > u){
int a = v;
v = u;
u = a;
}
p[u] = v;
sz[v] += sz[u];
for(int i = 0; i < N; i++)cnt[v][i] += cnt[u][i], cnt[i][v] = cnt[v][i];
return 1;
}
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |