Submission #810944

#TimeUsernameProblemLanguageResultExecution timeMemory
810944parsadox2Food Court (JOI21_foodcourt)C++14
100 / 100
968 ms63120 KiB
#include <bits/stdc++.h> using namespace std; const int maxn = 25e4 + 5; int n , m , q , c[maxn] , ans[maxn]; long long k[maxn]; vector <int> ask[maxn] , all[2][maxn]; struct nod{ long long sum , sum_neg , suf_sum; nod() { sum = 0; sum_neg = 0; suf_sum = 0; } } tree[maxn << 2]; inline nod Merge(nod a , nod b) { nod res; res.sum_neg = a.sum_neg + b.sum_neg; res.sum = a.sum + b.sum; res.suf_sum = max(b.suf_sum , b.sum + a.suf_sum); return res; } void Add(int ind , int val , int ty = 1 , int node = 1 , int nl = 0 , int nr = q) { if(nr - nl == 1) { tree[node].sum = 1LL * ty * val; tree[node].sum_neg = min(0LL , tree[node].sum); tree[node].suf_sum = max(tree[node].sum , 0LL); return; } int mid = (nl + nr) >> 1 , lc = node << 1 , rc = lc | 1; if(ind < mid) Add(ind , val , ty , lc , nl , mid); else Add(ind , val , ty , rc , mid , nr); tree[node] = Merge(tree[lc] , tree[rc]); } nod Get(int l , int r , int node = 1 , int nl = 0 , int nr = q) { if(r <= nl || nr <= l) { nod tmp; return tmp; } if(l <= nl && nr <= r) return tree[node]; int mid = (nl + nr) >> 1 , lc = node << 1 , rc = lc | 1; return Merge(Get(l , r , lc , nl , mid) , Get(l , r , rc , mid , nr)); } inline int solve(int ind) { nod check = Get(0 , ind); long long val = k[ind]; if(check.suf_sum < val) return 0; int low = -1 , high = ind - 1; while(high - low > 1) { int mid = (high + low) >> 1; nod g1 = Get(0 , mid + 1) , g2 = Get(mid + 1 , ind); long long tmp = g1.suf_sum + g2.sum_neg; if(tmp >= val) high = mid; else low = mid; } return c[high]; } signed main() { ios::sync_with_stdio(false); cin.tie(0); cout.tie(0); memset(ans , -1 , sizeof ans); cin >> n >> m >> q; for(int i = 0 ; i < q ; i++) { int ty; cin >> ty; if(ty == 1) { int l , r; cin >> l >> r >> c[i] >> k[i]; all[0][l].push_back(i); all[1][r].push_back(i); } else if(ty == 2) { int l , r; cin >> l >> r >> k[i]; k[i] = -1LL * k[i]; all[0][l].push_back(i); all[1][r].push_back(i); } else { int a; cin >> a >> k[i]; ask[a].push_back(i); } } for(int i = 1 ; i <= n ; i++) { for(auto u : all[0][i]) Add(u , k[u]); for(auto u : ask[i]) ans[u] = solve(u); for(auto u : all[1][i]) Add(u , k[u] , 0); } for(int i = 0 ; i < q ; i++) if(ans[i] != -1) cout << ans[i] << '\n'; return 0; }
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...