LCIS | ||||||
|
||||||
Description | ||||||
Given n integers. You have two operations: U A B: replace the Ath number by B. (index counting from 0) Q A B: output the length of the longest consecutive increasing subsequence (LCIS) in [a, b]. |
||||||
Input | ||||||
T in the first line, indicating the case number. Each case starts with two integers n , m(0<n,m<=105). The next line has n integers(0<=val<=105). The next m lines each has an operation: U A B(0<=A,n , 0<=B=105) OR Q A B(0<=A<=B< n). |
||||||
Output | ||||||
For each Q, output the answer. | ||||||
Sample Input | ||||||
1 10 10 7 7 3 3 5 9 9 8 1 8 Q 6 6 U 3 4 Q 0 1 Q 0 5 Q 4 7 Q 3 5 Q 0 2 Q 4 6 U 6 10 Q 0 9 | ||||||
Sample Output | ||||||
1 1 4 2 3 1 2 5 | ||||||
Recommend | ||||||
`Wind @Hrbust | ||||||
Author | ||||||
shǎ崽 |
#include<cstdio> #include<cmath> #include<queue> const int SIZE=100005; int LC[SIZE<<2]; int RC[SIZE<<2]; int CS[SIZE<<2]; int a[SIZE]; int N,M; template <class typeone> typeone max(typeone x,typeone y) { return x>y? x:y; } template <class typeone > typeone min(typeone x,typeone y) { return x<y? x:y; } void pushup(int l,int r,int lr) { LC[lr]=LC[lr<<1]; RC[lr]=RC[lr<<1|1]; CS[lr]=0; int m=(l+r)>>1; if(a[m]<a[m+1]) { CS[lr]=RC[lr<<1]+LC[lr<<1|1]; if(LC[lr]==m-l+1) { LC[lr]+=LC[lr<<1|1]; } if(RC[lr]==r-m) { RC[lr]+=RC[lr<<1]; } } CS[lr]=max(CS[lr],max(CS[lr<<1],CS[lr<<1|1])); return; } void build(int l,int r,int rt) { LC[rt]=RC[rt]=CS[rt]=0; if(l==r) { LC[rt]=RC[rt]=CS[rt]=1; scanf("%d",&a[l]); return ; } int m=(l+r)>>1; build(l,m,rt<<1); build(m+1,r,rt<<1|1); pushup(l,r,rt); return ; } void update(int pos,int l,int r,int rt,int val) { if(l==pos&&r==pos) { a[pos]=val; return; } int m=(l+r)>>1; if(pos<=m) { update(pos,l,m,rt<<1,val); } else { update(pos,m+1,r,rt<<1|1,val); } pushup(l,r,rt); return ; } int query(int L,int R,int l,int r,int rt) { if(L<=l&&R>=r) { return CS[rt]; } int m=(l+r)>>1; if(R<=m) { return query(L,R,l,m,rt<<1); } else if(L>m) { return query(L,R,m+1,r,rt<<1|1); } else { int t1=0,t2=0,t3=0; t1=query(L,R,l,m,rt<<1); t2=query(L,R,m+1,r,rt<<1|1); if(a[m]<a[m+1]) { t3=min(LC[rt<<1|1],R-m)+min(RC[rt<<1],m-L+1); } return max(t3,max(t1,t2)); } } int main() { int T; while(~scanf("%d",&T)) { while(T--) { char k[2]; scanf("%d %d",&N,&M); build(1,N,1); int x,y; // getchar(); while(M--) { scanf("%s %d %d",&k,&x,&y); if(strcmp(k,"Q")==0) { printf("%d\n",query(x+1,y+1,1,N,1)); } else { update(x+1,1,N,1,y); } } } } return 0; }