Submission #769906

#TimeUsernameProblemLanguageResultExecution timeMemory
769906BlockOGFountain (eJOI20_fountain)C++14
30 / 100
1563 ms1500 KiB
#include <iostream> #include <vector> #include <utility> #include <algorithm> #include <cstring> #include <set> #include <cmath> using namespace std; int main() { ios::sync_with_stdio(false); cin.tie(NULL); cout.tie(NULL); int n, q; cin >> n >> q; int diameters[n]; int next[n]; int capacities[n]; for (int i = 0; i < n; i++) cin >> diameters[i] >> capacities[i]; bool all_increasing = true; for (int i = 0; i < n; i++) { next[i] = n; for (int j = i + 1; j < n; j++) { if (diameters[j] > diameters[i]) { next[i] = j; break; } all_increasing = false; } } if (false && all_increasing) { for (int i = 1; i < n; i++) diameters[i] += diameters[i - 1]; for (int iq = 0; iq < q; iq++) { int r, v; cin >> r >> v; r--; if (r > 0) v += diameters[r - 1]; if (v > diameters[n - 1]) { cout << 0 << endl; continue; } cout << lower_bound(diameters, diameters + n, v) - diameters + 1 << endl; } } else { for (int iq = 0; iq < q; iq++) { int r, v; cin >> r >> v; r--; for (; r < n; r = next[r]) { v -= capacities[r]; if (v <= 0) break; } if (r == n) cout << 0 << endl; else cout << r + 1 << endl; } } }
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...