제출 #599140

#제출 시각아이디문제언어결과실행 시간메모리
599140pakhomovee커다란 상품 (IOI17_prize)C++17
20 / 100
107 ms316 KiB
#include "prize.h" #include <vector> #include <map> int find_best(int n) { int pr = 0; std::map<int, int> d; 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 (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...