Submission #158029

#TimeUsernameProblemLanguageResultExecution timeMemory
158029NachoLibreCave (IOI13_cave)C++14
100 / 100
1254 ms588 KiB
#include <bits/stdc++.h>
#include "cave.h"
using namespace std;

int s[5003], d[5003], g[5003], n;
bool vp[5003], am;

int tos(int l, int r, bool st) {
	for(int i = 0; i < n; ++i) {
		if(!vp[i]) s[i] = st ^ (i < l || i > r);
	}
	return tryCombination(s);
}

void exploreCave(int N) {
	n = N;
	for(int i = 0; i < n; ++i) {
		if(tos(0, n - 1, 0) == i) am = 0;
		else am = 1;
		int l = 0, r = n - 1, m;
		while(l < r) {
			m = (l + r) / 2;
			if(tos(l, m, am) == i) {
				r = m;
			} else {
				l = m + 1;
			}
		}
		vp[l] = 1;
		d[l] = i;
		s[l] = am ^ 1;
	}
	answer(s, d);
	return;
}
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...