题意:

T个测试数据

n个数 q个查询

n个数 ( 下标从0开始)

Q u v 查询 [u, v ] 区间最长连续上升子序列

U u v 把u位置改成v

#include<iostream>
#include<stdio.h>
#include<string.h>
#include<algorithm>
using namespace std;
#define N 101010
#define L(x) (x<<1)
#define R(x) (x<<1|1)
inline int Max(int a,int b){return a>b?a:b;}
inline int Min(int a,int b){return a<b?a:b;} struct node
{
int l,r;
int mid(){ return (l+r)>>1; }
int len(){ return r-l+1; }
int Llen, Rlen, maxlen; }tree[4*N];
int a[N];
void updata_up(int id){
tree[id].Llen = tree[L(id)].Llen;
tree[id].Rlen = tree[R(id)].Rlen;
tree[id].maxlen = Max( tree[L(id)].maxlen, tree[R(id)].maxlen); if( a[ tree[L(id)].r ] < a[ tree[R(id)].l ] )
{
if( tree[L(id)].Llen == tree[L(id)].len())
{
tree[id].Llen += tree[R(id)].Llen;
tree[id].maxlen = Max( tree[id].maxlen, tree[id].Llen);
}
if( tree[R(id)].Rlen == tree[R(id)].len() )
{
tree[id].Rlen += tree[L(id)].Rlen;
tree[id].maxlen = Max( tree[id].maxlen, tree[id].Rlen);
}
tree[id].maxlen = Max( tree[id].maxlen, tree[L(id)].Rlen + tree[R(id)].Llen ); } }
void build(int l, int r, int id){
tree[id].l = l, tree[id].r = r; if(l==r){ tree[id].Llen = tree[id].Rlen = tree[id].maxlen =1; return ; } int mid = (l+r)>>1;
build(l, mid, L(id));
build(mid+1, r, R(id));
updata_up(id);
} void updata(int pos,int id){
if(tree[id].l == tree[id].r)return ; int mid = tree[id].mid();
if( pos <= mid ) updata(pos, L(id));
else updata(pos, R(id));
updata_up(id);
} int query(int l, int r, int id){
if( l == tree[id].l && tree[id].r == r)
return tree[id].maxlen; int mid = tree[id].mid();
if(r <= mid)return query(l, r, L(id));
else if(mid < l) return query(l, r, R(id)); int L = query(l, mid, L(id)), R = query(mid+1, r, R(id)); if( a[mid] < a[mid+1] ){
int LL = Min( mid - l + 1, tree[L(id)].Rlen);
int RR = Min( r - mid, tree[R(id)].Llen);
return Max( Max(L,R), LL+RR);
}
else return Max(L, R);
} int main(){
int T,n,q,i; scanf("%d",&T);
while(T--){
scanf("%d %d", &n, &q);
for(i=1;i<=n;i++)scanf("%d",&a[i]); build(1, n, 1);
while(q--)
{
char c = '-';
while(c!='Q' && c!='U') c = getchar();
int u,v; scanf("%d %d", &u, &v); if(c == 'Q')
printf("%d\n", query(u+1, v+1, 1));
else if(c == 'U')
{ a[u+1] = v; updata(u+1, 1); } }
}
return 0;
}
/*
99
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 10 99
1 2 3 4 5 6 7 8 9 10
Q 4 7
U 0 8
Q 0 9
U 8 8 Q 0 9 */

HDU 3308 线段树 最长连续上升子序列 单点更新 区间查询的更多相关文章

  1. HDU 3308 线段树求区间最长连续上升子序列长度

    题意:两种操作,Q L R查询L - R 的最长连续上升子序列长度,U pos val 单点修改值 #include <bits/stdc++.h> #define N 100005 us ...

  2. hdu 3308(线段树区间合并)

    LCIS Time Limit: 6000/2000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others)Total Submis ...

  3. hdu 3308 线段树

    题目大意:给n个数,两种操作1:U  a b   更新第a个为b (从0开始)2: Q    a ,b  查询 a,b之间LCIS(最长连续递增子序列)的长度. Sample Input110 107 ...

  4. HDU 3308 线段树单点更新+区间查找最长连续子序列

    LCIS                                                              Time Limit: 6000/2000 MS (Java/Oth ...

  5. hdu 3308 线段树,单点更新 求最长连续上升序列长度

    LCIS Time Limit: 6000/2000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others)Total Submis ...

  6. hdu 3308 线段树 区间合并+单点更新+区间查询

    LCIS Time Limit: 6000/2000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others)Total Submis ...

  7. hdu 3397 线段树双标记

    Sequence operation Time Limit: 10000/5000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Othe ...

  8. hdu 2871 线段树(各种操作)

    Memory Control Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) T ...

  9. hdu 1166 线段树(sum+单点修改)

    敌兵布阵 Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others) Total Submi ...

随机推荐

  1. parameter和argument的区别

    根据网上一些资料,对parameter和argument的区别,做如下的简单说明.1. parameter是指函数定义中参数,而argument指的是函数调用时的实际参数.2. 简略描述为:param ...

  2. Python GUI编程实践

    看完了<python编程实践>对Python的基本语法有了一定的了解,加上认识到python在图形用户界面和数据库支持方面快捷,遂决定动手实践一番. 因为是刚接触Python,对于基本的数 ...

  3. const 的全面总结

    可以定义const常量 const int Max = 100; 2 便于进行类型检查 const常量有数据类型,而宏常量没有数据类型.编译器可以对前者进行类型安全检查,而对后者只进行字符替换,没有类 ...

  4. 20145120 《Java程序设计》第1周学习总结

    20145120 <Java程序设计>第1周学习总结 教材学习内容总结 刚刚开始学习java,感觉还十分陌生,在第一周的学习中,我知道了java的历史,JVM.JRE和JDK是什么等各种知 ...

  5. openstack安装、卸载与启动

    一.安装: 更新: sudo apt-get update sudo apt-get upgrade 安装图形化界面: sudo apt-get install ubuntu-desktop 安装gc ...

  6. Valid format values for declare-styleable/attr tags[转]

    http://chaosinmotion.com/blog/?p=179 reference string color dimension boolean integer float fraction ...

  7. Careercup - Facebook面试题 - 4713484755402752

    2014-05-02 00:30 题目链接 原题: Given two arrays of sorted integers, merge them keeping in mind that there ...

  8. p1205单词翻转-递归解决

    题目描述 Description 给出一个英语句子,希望你把句子里的单词顺序都翻转过来 输入描述 Input Description 输入包括一个英语句子. 输出描述 Output Descripti ...

  9. 网站常用css必备css reset

    在我们写前端代码页面的时候,很多常用的CSS类都是固定的!但没有一个标准或者大家都按自己的方式去随意的写,这样就每次都重复写一些固定的类! 为此HTML5 Doctor(HTML5医生)为我们总结了一 ...

  10. 17.2 The DispatcherServlet

    综述: Spring’s web MVC framework is, like many other web MVC frameworks, request-driven, designed arou ...