Submission #833930

#TimeUsernameProblemLanguageResultExecution timeMemory
833930JosiaThe Big Prize (IOI17_prize)C++17
20 / 100
3069 ms460 KiB
#include "prize.h"
using namespace std;
#include <bits/stdc++.h>


map<int, vector<int>> rem;
vector<int> myAsk(int pos) {
	if (rem.count(pos)) return rem[pos];
	return rem[pos] = ask(pos);
}



int getNumBetter(vector<int> x) {
	return x[0]+x[1];
}


int find_best(int n) {
	rem.clear();
	int numBetter = 0;
	int ind = 0;

	for (int i = 0; i<min(n, 1000); i++) {
		int hereBetter = getNumBetter(myAsk(i));
		if (hereBetter > numBetter) {
			numBetter = hereBetter;
			ind = i;
		}
	}

	set<int> candidates;
	for (int i=0; i<ind; i++) candidates.insert(i);

	int pos = ind;

	int oldL=-1, oldR=-1;
	while (true) {
		int l = pos+1, r = n-1;
		while (l<r) {
			int m = (l+r)/2;
			vector<int> ans = myAsk(m);

			if (getNumBetter(ans) < numBetter) {
				r = m;
				continue;
			}

			if (ans[1] < numBetter-candidates.size()) {
				r = m;
			}
			else l = m+1;
		}

		int pos = l;

		while (pos < n && getNumBetter(myAsk(pos)) < numBetter) {
			candidates.insert(pos);
			pos++;
		}

		if (candidates.size() == numBetter) break;

	}

	for (int i: candidates) {
		if (getNumBetter(myAsk(i)) == 0) return i;
	}

	assert(0);
}

Compilation message (stderr)

prize.cpp: In function 'int find_best(int)':
prize.cpp:49:15: warning: comparison of integer expressions of different signedness: '__gnu_cxx::__alloc_traits<std::allocator<int>, int>::value_type' {aka 'int'} and 'std::set<int>::size_type' {aka 'long unsigned int'} [-Wsign-compare]
   49 |    if (ans[1] < numBetter-candidates.size()) {
prize.cpp:62:25: warning: comparison of integer expressions of different signedness: 'std::set<int>::size_type' {aka 'long unsigned int'} and 'int' [-Wsign-compare]
   62 |   if (candidates.size() == numBetter) break;
      |       ~~~~~~~~~~~~~~~~~~^~~~~~~~~~~~
prize.cpp:37:6: warning: unused variable 'oldL' [-Wunused-variable]
   37 |  int oldL=-1, oldR=-1;
      |      ^~~~
prize.cpp:37:15: warning: unused variable 'oldR' [-Wunused-variable]
   37 |  int oldL=-1, oldR=-1;
      |               ^~~~
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...