Submission #641156

#TimeUsernameProblemLanguageResultExecution timeMemory
641156Tenis0206Santa Claus (RMI19_santa)C++11
100 / 100
342 ms10932 KiB
#include <bits/stdc++.h> using namespace std; int n; int x[100005],v[100005]; bool h[100005]; int rez[100005],r[100005]; int nr_left = 0; int ai[500005],lazy[500005]; void preset(int nod, int a, int b) { ai[nod] = lazy[nod] = 0; if(a==b) { return; } int mij = (a + b) >> 1; preset(nod*2,a,mij); preset(nod*2+1,mij+1,b); } void propag(int nod) { if(!lazy[nod]) { return; } ai[nod*2] += lazy[nod]; ai[nod*2+1] += lazy[nod]; lazy[nod*2] += lazy[nod]; lazy[nod*2+1] += lazy[nod]; lazy[nod] = 0; return; } void update(int ua, int ub, int val, int nod, int a, int b) { if(ua<=a && ub>=b) { ai[nod] += val; lazy[nod] += val; return; } propag(nod); int mij = (a + b) >> 1; if(ua<=mij) { update(ua,ub,val,nod*2,a,mij); } if(ub>mij) { update(ua,ub,val,nod*2+1,mij+1,b); } ai[nod] = min(ai[nod*2],ai[nod*2+1]); } void add_elf(int val) { update(val,n,-1,1,1,n); } void remove_elf(int val) { update(val,n,+1,1,1,n); } void add_child(int val) { update(val,n,+1,1,1,n); } void remove_child(int val) { update(val,n,-1,1,1,n); } bool is_ok() { return (ai[1] >= 0); } void solve_test() { cin>>n; for(int i=1; i<=n; i++) { cin>>x[i]; } int last_elf = 0; for(int i=1; i<=n; i++) { cin>>h[i]; if(!h[i]) { last_elf = i; } } for(int i=1; i<=n; i++) { cin>>v[i]; } int j = 0; multiset<int> s; int l_poz = 0; for(int i=1;i<=n;i++) { while(j<n && (!is_ok() || j<last_elf || j<i)) { ++j; if(h[j]) { add_child(v[j]); } else { add_elf(v[j]); } } if(is_ok()) { r[i] = j; l_poz = i; } else { break; } if(h[i]==0) { s.insert(v[i]); } else { remove_child(v[i]); auto dr = s.lower_bound(v[i]); if(dr!=s.end()) { remove_elf(*dr); s.erase(dr); } } } r[l_poz+1] = n + 1; for(int i=1;i<r[1];i++) { rez[i] = -1; } for(int i=1;i<=l_poz;i++) { for(int j=r[i];j<r[i+1];j++) { rez[j] = 2 * x[j] - x[i]; } } for(int i=1;i<=n;i++) { cout<<rez[i]<<' '; } cout<<'\n'; preset(1,1,n); } int main() { ios::sync_with_stdio(false); cin.tie(0); // freopen("nr.in","r",stdin); // freopen("nr.out","w",stdout); int t; cin>>t; for(int test=1; test<=t; test++) { solve_test(); } return 0; }
#Verdict Execution timeMemoryGrader output
Fetching results...