답안 #27190

# 제출 시각 아이디 문제 언어 결과 실행 시간 메모리
27190 2017-07-10T05:13:01 Z wangyenjen Park (JOI17_park) C++14
47 / 100
176 ms 2120 KB
// 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);
}

inline static void subtask3() {
    vector<int> now_lev;
    vector<int> vec;
    for(int i = 1; i < N; i++) {
        place[i] = 0;
        vec.push_back(i);
    }
    place[0] = 1;
    now_lev.push_back(0);
    while(!vec.empty()) {
        vector<int> vec2;
        vector<int> vec3;
        for(int x : vec) {
            place[x] = 1;
            if(Ask(0 , x , place)) vec2.push_back(x);
            else vec3.push_back(x);
            place[x] = 0;
        }
        vec = vec3;
        for(int x : vec2) {
            int lb = 0 , rb = (int)now_lev.size() - 1;
            place[x] = 1;
            while(lb < rb) {
                int mid = (lb + rb) >> 1;
                for(int i = lb; i <= mid; i++) place[now_lev[i]] = 0;
                int t = Ask(0 , x , place);
                for(int i = lb; i <= mid; i++) place[now_lev[i]] = 1;
                if(t) lb = mid + 1;
                else rb = mid;
            }
            Answer(min(now_lev[lb] , x) , max(now_lev[lb] , x));
        }
        now_lev = vec2;
    }
}

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();
}
# 결과 실행 시간 메모리 Grader output
1 Correct 0 ms 2120 KB Output is correct
2 Correct 6 ms 2120 KB Output is correct
3 Correct 6 ms 2120 KB Output is correct
4 Correct 6 ms 2120 KB Output is correct
5 Correct 6 ms 2120 KB Output is correct
# 결과 실행 시간 메모리 Grader output
1 Correct 169 ms 2120 KB Output is correct
2 Correct 59 ms 2120 KB Output is correct
3 Correct 66 ms 2120 KB Output is correct
4 Correct 173 ms 2120 KB Output is correct
5 Correct 173 ms 2120 KB Output is correct
# 결과 실행 시간 메모리 Grader output
1 Correct 133 ms 2120 KB Output is correct
2 Correct 146 ms 2120 KB Output is correct
3 Correct 146 ms 2120 KB Output is correct
4 Correct 136 ms 2120 KB Output is correct
5 Correct 139 ms 2120 KB Output is correct
6 Correct 136 ms 2120 KB Output is correct
7 Correct 153 ms 2120 KB Output is correct
8 Correct 176 ms 2120 KB Output is correct
# 결과 실행 시간 메모리 Grader output
1 Correct 69 ms 2120 KB Output is correct
2 Incorrect 86 ms 2120 KB Wrong Answer[5]
3 Halted 0 ms 0 KB -
# 결과 실행 시간 메모리 Grader output
1 Incorrect 23 ms 2120 KB Wrong Answer[2]
2 Halted 0 ms 0 KB -