이 제출은 이전 버전의 oj.uz에서 채점하였습니다. 현재는 제출 당시와는 다른 서버에서 채점을 하기 때문에, 다시 제출하면 결과가 달라질 수도 있습니다.
#include <bits/stdc++.h>
#include "cave.h"
using namespace std;
const int maxn = 5e3+10;
int n;
int door[maxn], known[maxn], state[maxn], query[maxn];
bool open(int ans, int k){
return (ans == -1 ? 1 : ans > k);
}
void dc(int l, int r, int id, int state_id){
if(l==r){
door[l] = id;
known[l] = true;
state[l] = state_id;
return;
}
int mid = (l+r) >> 1;
memset(query, state_id^1, sizeof query);
for(int i=l; i<=mid; i++){
query[i] = state_id;
}
for(int i=0; i<n; i++){
if(known[i]) query[i] = state[i];
}
if(open(tryCombination(query), id)) dc(l, mid, id, state_id);
else dc(mid+1, r, id, state_id);
}
void exploreCave(int N) {
n = N;
for(int i=0; i<n; i++){
memset(query, 0, sizeof query);
for(int j=0; j<n; j++){
if(known[j]) query[j] = state[j];
}
if(open(tryCombination(query), i)) dc(0, n, i, 0);
else dc(0, n, i, 1);
}
answer(state, door);
}
# | 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... |