题意:

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. Teradata中fastload使用

    Teradata Fastload Utility 是teradata数据库中一个基于命令行的快速load大量数据到一个空表的工具. 数据可以从以下途径被load: 1) Disk 或 tape; 2 ...

  2. JAVA算术运算符、关系运算符和位运算符

    算术运算符 1.java的算数运算符包括+(加).-(减).*(乘)./(除).%(取余),在运算过程中出现的隐式转换原则和C语言一样:2. 高位数据向低位数据转化要使用强制转化: 关系运算符 1.j ...

  3. cocos2dx中的坐标体系

    1.UI坐标系和GL坐标系 2.本地坐标与世界坐标 本地坐标是一个相对坐标,是相对于父节点或者你指明的某个节点的相对位置来说的,本地坐标的原点在参考节点的左下角 世界坐标是一个绝对的坐标,是以屏幕的左 ...

  4. extern "C"——用“C”来规约在C++中用C的方式进行编译和链接

    C++中的extern “C”用法详解     extern "C"表明了一种编译规约,其中extern是关键字属性,“C”表征了编译器链接规范.对于extern "C& ...

  5. .net datatable 添加一列

    dt.Columns.Add("image", Type.GetType("System.String")); foreach (DataRow dr in d ...

  6. Chrome浏览器下调试SASS

    网上说的方案各有各的说法,尝试多个才找到有效方案,为避免后来者麻烦,现在讲讲如何调试 笔者ruby版本为3.4.19,因为sass文件的编译是需要ruby环境的,使用sass前需要先安装! 第一步(核 ...

  7. MoveManager管理类

    MoveManager:移动管理类 struct MoveOpt { int cur_seq; ObjecInfo* obj; }; std::map<ObjID, MoveOpt> m_ ...

  8. 高性能网络编程1----accept建立连接

    转 http://taohui.org.cn/tcpperf1.html  陶辉 taohui.org.cn 回到应用层,往往只需要调用类似于accept的API就可以建立TCP连接.建立连接的流程大 ...

  9. [设计模式] 23 访问者模式 visitor Pattern

    在GOF的<设计模式:可复用面向对象软件的基础>一书中对访问者模式是这样说的:表示一个作用于某对象结构中的各元素的操作.它使你可以在不改变各元素的类的前提下定义作用于这些元素的新操作.访问 ...

  10. python中精确输出JSON浮点数的方法

    有时需要在JSON中使用浮点数,比如价格.坐标等信息.但python中的浮点数相当不准确, 例如下面的代码: 复制代码代码如下: #!/usr/bin/env python import json a ...