1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69
| #include<bits/stdc++.h> #define inf 0x3f3f3f3f3f3f3f3fll #define debug(x) cerr<<#x<<"="<<x<<endl using namespace std; using ll=long long; inline int read() { int s=0,w=1;char ch; while((ch=getchar())>'9'||ch<'0') if(ch=='-') w=-1; while(ch>='0'&&ch<='9') s=s*10+ch-'0',ch=getchar(); return s*w; } struct node { int lma,rma; int c,sum; inline node operator + (node b) { node ans; ans.sum=sum+b.sum; ans.lma=max(lma,sum+b.lma); ans.rma=max(b.rma,b.sum+rma); ans.c=max(max(c,b.c),rma+b.lma); return ans; } }num[2000001]; char s[500005]; int n,m; void build(int p,int pl,int pr) { if(pl==pr) { if(s[pl]=='C') num[p].sum=num[p].lma=num[p].rma=num[p].c=1; else num[p].sum=-1; return ; } int mid=(pl+pr)>>1; build(p*2,pl,mid); build(p*2|1,mid+1,pr); num[p]=num[p*2]+num[p*2|1]; } node get(int p,int pl,int pr,int l,int r) { if(l<=pl&&pr<=r) return num[p]; int mid=(pl+pr)>>1; if(l<=mid) { if(mid>=r) return get(p*2,pl,mid,l,r); } if(mid<r) { if(l>mid) return get(p*2|1,mid+1,pr,l,r); } return get(p*2,pl,mid,l,r)+get(p*2|1,mid+1,pr,l,r); } int main() { n=read(); scanf("%s",s+1); build(1,1,n); m=read(); for(int i=1;i<=m;i++) { int l=read(),r=read(); node ans=get(1,1,n,l,r); printf("%d\n",ans.c-ans.sum); } return 0; }
|