Submission #487810

#TimeUsernameProblemLanguageResultExecution timeMemory
487810leakedNew Home (APIO18_new_home)C++14
47 / 100
5076 ms353284 KiB
#include <bits/stdc++.h> #define f first #define s second #define sz(x) (int)(x).size() #define pb push_back #define all(x) (x).begin(),(x).end() #define rall(x) (x).rbegin(),(x).rend() #define vec vector #define pw(x) (1LL<<(x)) #define m_p make_pair #define fast_iati ios_base::sync_with_stdio(false);cin.tie(0);cout.tie(0); using namespace std; template <class T> bool umin(T &a,const T &b){return (a>b?a=b,1:0);} template <class T> bool umax(T &a,const T &b){return (a<b?a=b,1:0);} typedef long long ll; typedef pair<int,int> pii; const int N=3e5+100; bool del[5*N]; struct segtree{ priority_queue<pii> st[2*N+1]; void add(int l,int r,int tp,pii x,int v,int tl,int tr){ l+=N,r+=N; r++; while(l<r) { if (l&1) st[l++].push(x); if (r&1) st[--r].push(x); l>>=1;r>>=1; } } int get(int id){ int ans=-1e9; id+=N; while(id>0){ while(sz(st[id]) && del[st[id].top().s]) st[id].pop(); if(sz(st[id])) umax(ans,st[id].top().f); id>>=1; } return ans; } }lft,rgt; vec<int> kek; map<pii,int>mp; int tmr; int gl(int x){ return upper_bound(all(kek),x)-kek.begin()-1; } int gu(int x){ return upper_bound(all(kek),x)-kek.begin(); } void add(int l,int r,int t,int tp){ if(l==r) return; int mid=(l+r)>>1; if(!t){ del[mp[{l,tp}]]=1; return; } mp[{l,tp}]=tmr; if(gl(mid)>=0){ lft.add(gl(l),gl(mid),t,{-l,tmr},1,0,sz(kek)-1); } if(gl(mid)+1<=gl(r)) rgt.add(gl(mid)+1,gl(r),t,{r,tmr},1,0,sz(kek)-1); ++tmr; } const int Nax=3e5+1; multiset<int> st[N]; vec<int>here[N]; signed main(){ fast_iati; int n,q,k; cin>>n>>k>>q; vec<array<int,3>>arr; vec<int>x(n),a(n),b(n),t(n); for(int i=0;i<n;i++){ cin>>x[i]>>t[i]>>a[i]>>b[i]; // x[i]=rand(),t[i]=rand()%k+1; // a[i]=rand(),b[i]=rand(); // if(a[i]>b[i]) // swap(a[i],b[i]); // kek.pb(x[i]); arr.pb({a[i],0,i}); arr.pb({b[i]+1,-1,i}); --t[i]; here[t[i]].pb(i); } vec<int>l(q),y(q); for(int i=0;i<q;i++){ cin>>l[i]>>y[i]; // l[i]=rand(),y[i]=rand(); kek.pb(l[i]); arr.pb({y[i],2,i}); } sort(all(kek));kek.erase(unique(all(kek)),kek.end()); sort(all(arr)); auto stupid=[&](array<int,3> z){ pii me={-1e9,0}; int tx=l[z[1]]; for(int j=0;j<k;j++){ if(sz(st[j])==2) continue; //// cout<<"TYP "<<endl; //// for(auto &z : st[j]) //// cout<<z<<' '; //// cout<<endl auto it=st[j].lower_bound(tx); int omn=2e9; if(it!=st[j].end()) umin(omn,*it-tx); if(it!=st[j].begin()) umin(omn,tx-*prev(it)); umax(me.f,omn);me.s++; } return me; }; auto solve=[&](array<int,3> z){ int x=l[z[1]]; x=gl(x); int fe=lft.get(x)+l[z[1]]; int si=rgt.get(x)-l[z[1]]; return max(fe,si); }; vec<int>cnt(k,0); for(int i=0;i<k;i++){ add(-3e8,3e8,1,i); st[i].insert(-3e8); st[i].insert(3e8); } int total=0; vec<int>ans(q,-1); for(auto &z : arr){ swap(z[1],z[2]); if(z[2]==2){ if(total!=k){ ans[z[1]]=-1; continue; } int rio=solve(z); ans[z[1]]=rio; } else if(z[2]==-1){ int i=z[1]; auto it=st[t[i]].lower_bound(x[i]); add(x[i],*next(it),0,t[i]); add(*prev(it),x[i],0,t[i]); add(*prev(it),*next(it),1,t[i]); st[t[i]].erase(it); cnt[t[i]]--; if(!cnt[t[i]]) total--; } else{ int i=z[1]; if(!cnt[t[i]]) total++; cnt[t[i]]++; st[t[i]].insert(x[i]); auto it=st[t[i]].lower_bound(x[i]); add(*prev(it),*next(it),0,t[i]); add(x[i],*next(it),1,t[i]); add(*prev(it),x[i],1,t[i]); } } for(auto &z : ans) cout<<z<<'\n'; return 0; } /* 4 2 4 3 1 1 10 9 2 2 4 7 2 5 7 4 1 8 10 5 3 5 6 5 9 1 10 2 1 3 1 1 1 4 1 1 2 6 1 3 1 5 1 7 1 1 1 100000000 1 1 1 1 1 */

Compilation message (stderr)

new_home.cpp: In function 'int main()':
new_home.cpp:99:10: warning: variable 'stupid' set but not used [-Wunused-but-set-variable]
   99 |     auto stupid=[&](array<int,3> z){
      |          ^~~~~~
#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...