Submission #599144

#TimeUsernameProblemLanguageResultExecution timeMemory
599144pakhomoveeThe Big Prize (IOI17_prize)C++17
0 / 100
1 ms208 KiB
#include "prize.h" #include <vector> #include <map> int find_best(int n) { int pr = 0; std::map<int, int> d; std::vector<int> q = ask(0); int lt = q[0]; int rt = q[1]; int sm = lt + rt; if (sm == 0) { return 0; } while (pr != n) { int l = pr, r = n; while (l + 1 < r) { int m = (l + r) / 2; int have = 0; std::vector<int> q = ask(m); int lt = q[0]; int rt = q[1]; for (auto [x, y] : d) { if (lt + rt > x) { have += y; } } if (sm != lt + rt && lt - have) { r = m; } else { l = m; } } std::vector<int> arr = ask(l); if (arr[0] == arr[1] && arr[0] == 0) { return l; } ++d[arr[0] + arr[1]]; pr = l + 1; } return -1; }
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...