Submission #766774

#TimeUsernameProblemLanguageResultExecution timeMemory
766774danikoynovThe Big Prize (IOI17_prize)C++14
20 / 100
77 ms3388 KiB
#include "prize.h" #include<bits/stdc++.h> using namespace std; map < int, vector < int > > mp; map < int, int > used; vector < int > local_ask(int idx) { if (used[idx]) return mp[idx]; used[idx] = 1; mp[idx] = ask(idx); return mp[idx]; } int subsolve(vector < int > st) { /**for (int i = 0; i < st.size(); i ++) cout << st[i] << " "; cout << endl;*/ if (st.size() == 1) return st[0]; int nec = min((int)(st.size()), (int)(sqrt(st.size()) + 2)); int mx = -1, best = 0; for (int i = 0; i < nec; i ++) { vector < int > cur = local_ask(st[i]); if (cur[0] + cur[1] > best) { best = cur[0] + cur[1]; mx = i; } } vector < int > level; for (int i = 0; i < mx; i ++) level.push_back(st[i]); int t = mx, found = 0; ///cout << "here " << mx << endl; vector < int > base = local_ask(mx); while(t < st.size()) { int l = t + 1, r = st.size() - 1; ///cout << t << endl; while(l <= r) { int m = (l + r) / 2; vector < int > cur = local_ask(st[m]); if (cur[0] + cur[1] != best) r = m - 1; else { int bet = cur[0] - base[0] - found; if (bet != 0) r = m - 1; else l = m + 1; } } if (l == st.size()) break; t = l; found ++; level.push_back(st[t]); } return subsolve(level); } int find_best(int n) { vector < int > idc; for (int i = 0; i < n; i ++) idc.push_back(i); int ans = subsolve(idc); return ans; }

Compilation message (stderr)

prize.cpp: In function 'int subsolve(std::vector<int>)':
prize.cpp:41:13: warning: comparison of integer expressions of different signedness: 'int' and 'std::vector<int>::size_type' {aka 'long unsigned int'} [-Wsign-compare]
   41 |     while(t < st.size())
      |           ~~^~~~~~~~~~~
prize.cpp:60:15: warning: comparison of integer expressions of different signedness: 'int' and 'std::vector<int>::size_type' {aka 'long unsigned int'} [-Wsign-compare]
   60 |         if (l == st.size())
      |             ~~^~~~~~~~~~~~
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...