이 제출은 이전 버전의 oj.uz에서 채점하였습니다. 현재는 제출 당시와는 다른 서버에서 채점을 하기 때문에, 다시 제출하면 결과가 달라질 수도 있습니다.
#include "icc.h"
#include <vector>
#include <cstdio>
using namespace std;
vector<int> v,u;
int p[105];
int pa(int i) {return (p[i]==i)? i:p[i]=pa(p[i]);}
void unions(int i,int j){
i=pa(i);
j=pa(j);
p[i]=j;
}
void run(int n) {
for (int x=1;x<=n;x++){
p[x]=x;
}
u.push_back(0);
int a,b;
for (int _x=1;_x<n;_x++){
a=-1,b=-1;
while (b==-1){
for (int x=1;x<=n;x++){
u[0]=x;
v.clear();
for (int y=1;y<=n;y++){
if (pa(x)!=pa(y)) v.push_back(y);
}
int _u[]={u[0]};
int _v[v.size()];
for (int x=0;x<(int)v.size();x++) _v[x]=v[x];
if(query(1,v.size(),_u,_v)==1){
if (a==-1) a=x;
else b=x;
}
}
}
//printf("%d %d\n",a,b);
unions(a,b);
setRoad(a,b);
}
}
# | 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... |