This submission is migrated from previous version of oj.uz, which used different machine for grading. This submission may have different result if resubmitted.
#include<bits/stdc++.h>
#define endl '\n'
using namespace std;
void speed()
{
ios_base::sync_with_stdio(false);
cin.tie(NULL);
cout.tie(NULL);
/*#ifdef ONLINE_JUDGE
freopen("taxi.in", "r", stdin);
freopen("taxi.out", "w", stdout);
#endif
*/
}
int n,q;
string s[305];
string a[300005];
int l[300005],r[300005],safe[300005],last[300005],state[300005];
int answer(int l,int r,int ti)
{
int br=0;
for(int i=0; i<ti; i++)
{
for(int j=l; j<r; j++)
{
if(s[i][j]=='0')break;
if(j==r-1)br++;
}
}
return br;
}
void read()
{
cin>>n>>q>>s[0];
if(n<=100&&q<=100)
{
for(int i=1; i<=q; i++)
{
cin>>a[i]>>l[i];
l[i]--;
s[i]=s[i-1];
if(a[i]=="query")
{
cin>>r[i];
r[i]--;
cout<<answer(l[i],r[i],i)<<endl;
}
else
{
s[i][l[i]]++;
if(s[i][l[i]]=='2')s[i][l[i]]='0';
}
}
}
else
{
for(int i=0;i<n;i++)
{
if(s[0][i]=='1')state[i]=1;
}
for(int i=1;i<=q;i++)
{
cin>>a[i]>>l[i];
l[i]--;
if(a[i]=="toggle")
{
if(state[l[i]]==1)safe[l[i]]+=i-last[l[i]];
last[l[i]]=i;
state[l[i]]=(state[l[i]]+1)%2;
}
else
{
cin>>r[i];
cout<<safe[l[i]]+(i-last[l[i]])*state[l[i]]<<endl;
}
}
}
}
int main()
{
speed();
read();
return 0;
}
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |