Submission #596892

#TimeUsernameProblemLanguageResultExecution timeMemory
596892CookieFountain (eJOI20_fountain)C++14
60 / 100
74 ms6288 KiB
#include<bits/stdc++.h> using namespace std; #define ll long long #define vt vector #define pb push_back const int mxn = 2e5 + 3; int n, q; ll a[100001], b[100001]; int main(){ ios_base::sync_with_stdio(0); cin.tie(0); cout.tie(0); cin >> n >> q; for(int i = 1; i <= n; i++)cin >> a[i] >> b[i]; if(n <= 1000 && q <= 2000){ for(int i = 0; i < q; i++){ ll r, v; cin >> r >> v; if(v <= b[r]){ cout << r << "\n"; }else{ ll curr = a[r]; v -= b[r]; for(int j = r + 1; j <= n; j++){ if(a[j] > curr){ v -= b[j]; if(v <= 0){ cout << j << "\n"; break; } curr = a[j]; } } if(v > 0)cout << 0 << "\n"; } } }else{ ll p[n + 1] = {}; p[0] = 0; for(int i = 2; i <= n; i++)assert(a[i] > a[i - 1]); for(int i = 1; i <= n; i++)p[i] = p[i - 1] + b[i]; for(int i = 0; i < q; i++){ ll rr, v; cin >> rr >> v; int l = rr, r = n, ans = 0; while(l <= r){ int mid = (l + r) >> 1; if(p[mid] - p[rr - 1] >= v){ ans = mid; r = mid - 1; }else{ l = mid + 1; } } cout << ans << "\n"; } } }
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...