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>
using namespace std;
#define fast ios_base::sync_with_stdio();cin.tie();cout.tie();
#define en cout<<endl;
#define ops cout<<"ops"<<endl;
#define line cout<<"---------------------------"<<endl;
#define fi first
#define se second
typedef long long ll;
typedef long double ld;
typedef pair<ll,ll> pllll;
typedef string str;
const ll DIM = 1e2 + 7;
const ll DIMM = 5e4 + 7;
const ll DDIM = 7;
const ll INF = 1e18 + 7;
const ll X = 1e5 + 7;
const ll BS = 2e5 + 7;
const ll AS = 26 + 7;
const ll MODULO = 1e9 + 7;
ll nt,n,m,k,q;
str s,type[DIM];
ll v1[DIM],v2[DIM];
ll a[DIM],b[DIM];
ll cres;
bool f;
bool check(ll p1,ll p2){
for(int i=p1;i<p2;i++)
if(b[i]==0)return false;
return true;
}
int main()
{
fast;
//ll x1,y1,x2,y2;
cin>>n>>q>>s;
for(int i=0;i<n;i++)a[i+1]=s[i]-'0';
for(int qq=1;qq<=q;qq++){
cin>>type[qq]>>v1[qq];
if(type[qq]=="query"){
cin>>v2[qq];
cres=0;
for(int i=1;i<=n;i++)b[i]=a[i];
f=check(v1[qq],v2[qq]);
if(f)cres++;
for(int j=1;j<qq;j++){
if(type[j]=="toggle"){
b[v1[j]]=1-b[v1[j]];
f=check(v1[qq],v2[qq]);
}
if(f)cres++;
}
cout<<cres<<endl;
}
}
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... |