This submission is migrated from previous version of oj.uz, which used different machine for grading. This submission may have different result if resubmitted.
// Author: Wang, Yen-Jen
#include "park.h"
#include <bits/stdc++.h>
using namespace std;
static int N;
static int place[1400];
inline static void subtask1() {
memset(place , 0 , sizeof(place));
for(int i = 0; i < N; i++) {
for(int j = i + 1; j < N; j++) {
place[i] = 1;
place[j] = 1;
if(Ask(i , j , place)) Answer(i , j);
place[i] = 0;
place[j] = 0;
}
}
}
inline static void subtask2() {
for(int i = 0; i < N; i++) place[i] = 1;
vector<int> vec;
for(int i = 1; i < N - 1; i++) vec.push_back(i);
stable_sort(vec.begin() , vec.end() , [&](const int x , const int y) {
place[x] = 0;
int t = Ask(0 , y , place);
place[x] = 1;
return t == 0;
});
for(int i = 1; i < (int)vec.size(); i++) Answer(min(vec[i - 1] , vec[i]) , max(vec[i - 1] , vec[i]));
Answer(0 , vec[0]);
Answer(vec.back() , N - 1);
}
static void dfs_for_subtask3(int p , int l , int r , vector<int> &vec) {
// if(p == 3) printf("WW %d %d\n",l,r);
if(l > r) return;
for(int i = 0; i < N; i++) place[i] = 1;
for(int i = l; i <= r; i++) place[i] = 0;
place[p] = 1;
if(Ask(0 , p , place)) return;
if(l == r) {
vec.push_back(l);
return;
}
int m = (l + r) >> 1;
dfs_for_subtask3(p , l , m , vec);
dfs_for_subtask3(p , m + 1 , r , vec);
}
inline static void subtask3() {
static bool vis[1400];
static int dep[1400];
for(int i = 0; i < N; i++) {
vis[i] = 0;
dep[i] = 0;
}
dep[0] = 0;
vis[0] = 1;
for(int i = 1; i < N; i++) {
if(vis[i]) continue;
vector<int> vec , vec2;
vec.push_back(i);
dfs_for_subtask3(i , 1 , i - 1 , vec);
dfs_for_subtask3(i , i + 1 , N - 1 , vec);
int p = 0;
for(int x : vec) {
// printf("WWW %d\n",x);
if(vis[x]) {
if(dep[x] > dep[p]) p = x;
}
else {
vec2.push_back(x);
vis[x] = 1;
}
}
for(int j = 0; j < N; j++) place[j] = 1;
stable_sort(vec2.begin() , vec2.end() , [&](const int x , const int y) {
place[x] = 0;
int t = Ask(0 , y , place);
place[x] = 1;
return t == 0;
});
// printf("YYYY %d %d %d\n",p,vec2[0],i);
Answer(min(p , vec2[0]) , max(p , vec2[0]));
dep[vec2[0]] = dep[p] + 1;
for(int j = 1; j < (int)vec2.size(); j++) {
Answer(min(vec2[j - 1] , vec2[j]) , max(vec2[j - 1] , vec2[j]));
dep[vec2[j]] = dep[vec2[j - 1]] + 1;
}
// puts("");
}
}
void Detect(int T , int _N) {
N = _N;
if(N == 1) return;
else if(N == 2) {
Answer(0 , 1);
return;
}
if(T == 1) subtask1();
else if(T == 2) subtask2();
else subtask3();
}
# | 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... |