Submission #865963

#TimeUsernameProblemLanguageResultExecution timeMemory
865963jk410Street Lamps (APIO19_street_lamps)C++17
20 / 100
195 ms30008 KiB
#include <iostream> #include <vector> #include <algorithm> #include <set> #define all(v) v.begin(),v.end() using namespace std; struct interval{ int l,r,t; bool operator<(const interval &tmp)const{ if (l!=tmp.l) return l<tmp.l; return r<tmp.r; } }; struct query{ int t,mode,x,y; }; int N,Q,CntQ; vector<query> QV; string S; set<interval> Set; int Ans[300001]; int Tree[300001]; void fenwickUpdate(int x,int val){ while (x<=N){ Tree[x]+=val; x+=x&-x; } } int fenwickQuery(int x){ int ret=0; while (x){ ret+=Tree[x]; x-=x&-x; } return ret; } int main(){ ios::sync_with_stdio(0); cin.tie(0); cout.tie(0); cin>>N>>Q>>S; for (int i=1,j=0; i<=N; i++){ if (S[i-1]=='1'){ if (!j) j=i; if (i==N||S[i]=='0'){ Set.insert({j,i,0}); j=0; } } } for (int t=1; t<=Q; t++){ string s; cin>>s; if (s[0]=='t'){ int x; cin>>x; auto it=Set.lower_bound({x+1,x+1,0}); if (it!=Set.begin()&&prev(it)->r>=x){//x가 켜져 있음 interval cur=*(--it); QV.push_back({cur.r,0,cur.l,t-cur.t}); Set.erase(it); if (cur.l<x) Set.insert({cur.l,x-1,t}); if (x<cur.r) Set.insert({x+1,cur.r,t}); } else{//x가 꺼져 있음 interval cur={x,x,t}; if (it!=Set.begin()&&prev(it)->r==x-1){ cur.l=(--it)->l; QV.push_back({it->r,0,it->l,t-it->t}); it=Set.erase(it); } if (it!=Set.end()&&it->l==x+1){ cur.r=it->r; QV.push_back({it->r,0,it->l,t-it->t}); Set.erase(it); } Set.insert(cur); } } else{ CntQ++; int l,r; cin>>l>>r; r--; auto it=Set.lower_bound({l+1,l+1,0}); if (it!=Set.begin()&&prev(it)->r>=r) Ans[CntQ]+=t-prev(it)->t; QV.push_back({r-1,-1,CntQ,l}); QV.push_back({N,1,CntQ,l}); } } stable_sort(all(QV),[&](query a,query b)->bool{ return a.t<b.t; }); for (query i:QV){ if (i.mode) Ans[i.x]+=fenwickQuery(i.y)*i.mode; else fenwickUpdate(i.x,i.y); } for (int i=1; i<=CntQ; 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...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...