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>
#include"library.h"
#ifdef EVAL
#else
#include"grader.cpp"
#endif
using namespace std;
vector<int>g[205],ans;
void dfs(int v,int p){
ans.push_back(v+1);
for(int to:g[v])if(to!=p)dfs(to,v);
}
void Solve(int n){
vector<int>m(n,0);
for(int i=0;i+1<n;i++){
for(int j=i+1;j<n;j++){
m[i]=m[j]=1;
if(Query(m)==1){
g[i].push_back(j);
g[j].push_back(i);
}
m[i]=m[j]=0;
}
}
int root;
if(n==1)root=0;
else{
int l=0,r=n-1;
while(l<r){
int mid=(l+r)>>1;
vector<int>tmp=m;
for(int i=l;i<=mid;i++)tmp[i]=1;
int x=Query(tmp);
for(auto &to:tmp)to^=1;
int y=Query(tmp);
if(x>=y)r=mid;
else l=mid+1;
}
root=l;
}
dfs(root,root);
Answer(ans);
}
/*
9
7 2 1 6 4 8 3 9 5
*/
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |