Submission #797879

#TimeUsernameProblemLanguageResultExecution timeMemory
797879vjudge1Worst Reporter 3 (JOI18_worst_reporter3)C++17
12 / 100
148 ms15944 KiB
#include<bits/stdc++.h> using namespace std; using ll = long long; const int M = 1e3 + 10; const int N = 5e5 + 10; int n, q; ll d[N], T[N], L[N], R[N]; struct query { ll l, r, i, t; }; int main() { ios::sync_with_stdio(0); cin.tie(0);cout.tie(0); cin >> n >> q; for(int i = 1; i <= n; i++) cin >> d[i]; for(int i = 1; i <= q; i++) { cin >> T[i] >> L[i] >> R[i]; } if(n <= 1000 && q <= 1000) { int ans[q + 1] = {}; vector<query> g[M]; for(int i = 1; i <= q; i++) { g[T[i]].push_back({L[i], R[i], i, T[i]}); } vector<int> ar(n + 1); for(int i = 0; i <= n; i++) ar[i] = -i; for(int t = 1; t < M; t++) { ar[0]++; for(int i = 1; i <= n; i++) if(!i || ar[i - 1] - ar[i] > d[i]) ar[i] = ar[i - 1] - 1; // for(int c : ar) cout << c << ' '; // cout << '\n'; for(query cur : g[t]) { for(int c : ar) { ans[cur.i] += (cur.l <= c && c <= cur.r); } } } for(int i = 1; i <= q; i++) cout << ans[i] << '\n'; return 0; } }
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...