제출 #599198

#제출 시각아이디문제언어결과실행 시간메모리
599198pakhomoveeThe Big Prize (IOI17_prize)C++17
20 / 100
95 ms1328 KiB
#include "prize.h"
#include <vector>
#include <map>
#include <cassert>

int find_best(int n) {
    int pr = 0;
    std::map<int, int> d;
    int Q = 1;
    std::vector<int> q = ask(0);
      std::map<int, std::vector<int>> res;
      res[0] = q;
    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;
            if (!res.count(m)) {
                q = ask(m);
                res[m] = q;
            } else {
                q = res[m];
            }
              res[m] = q;
            ++Q;
            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;
          if (!res.count(l)) {
              arr = ask(l);
              res[l] = arr;
          } else {
              arr = res[l];
          }
        ++Q;
        if (arr[0] == arr[1] && arr[0] == 0) {
            return l;
        }
        ++d[arr[0] + arr[1]];
        pr = l + 1;
        assert(arr[1] > 0);
    }
    return -1;
}

#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...