题目大意:给一个整数序列,m次询问,每次询问某个区间中最长连续上升子序列的长度。

题目分析:线段树区间合并。维护以区间左端开头的、以区间右端点结尾的和区间最长的上升连续序列。

代码如下:

# include<bits/stdc++.h>
using namespace std;
# define LL long long
# define mid (l+(r-l)/2) const int N=100000; int w[N+5];
int len[N*4+5];
int l1[N*4+5],l3[N*4+5];
int r1[N*4+5],r3[N*4+5]; void pushUp(int rt,int l,int r)
{
len[rt]=0;
if(w[mid]<w[mid+1]){
if(r1[rt<<1]==mid) r1[rt]=r1[rt<<1|1];
else r1[rt]=r1[rt<<1];
if(l1[rt<<1|1]==mid+1) l1[rt]=l1[rt<<1];
else l1[rt]=l1[rt<<1|1]; if(r1[rt<<1|1]-l1[rt<<1]+1>len[rt]){
len[rt]=r1[rt<<1|1]-l1[rt<<1]+1;
l3[rt]=l1[rt<<1];
r3[rt]=r1[rt<<1|1];
}
}else{
l1[rt]=l1[rt<<1|1];
r1[rt]=r1[rt<<1];
}
if(r1[rt]-l+1>len[rt]){
len[rt]=r1[rt]-l+1;
l3[rt]=l,r3[rt]=r1[rt];
}
if(r-l1[rt]+1>len[rt]){
len[rt]=r-l1[rt]+1;
l3[rt]=l1[rt],r3[rt]=r;
}
if(r3[rt<<1]-l3[rt<<1]+1>len[rt]){
len[rt]=r3[rt<<1]-l3[rt<<1]+1;
l3[rt]=l3[rt<<1];
r3[rt]=r3[rt<<1];
}
if(r3[rt<<1|1]-l3[rt<<1|1]+1>len[rt]){
len[rt]=r3[rt<<1|1]-l3[rt<<1|1]+1;
l3[rt]=l3[rt<<1|1];
r3[rt]=r3[rt<<1|1];
}
} void build(int rt,int l,int r)
{
if(l==r){
len[rt]=1;
l1[rt]=r1[rt]=l;
l3[rt]=r3[rt]=l;
}else{
build(rt<<1,l,mid);
build(rt<<1|1,mid+1,r);
pushUp(rt,l,r);
}
} void update(int rt,int l,int r,int p,int x)
{
if(l==r){
w[l]=x;
}else{
if(p<=mid) update(rt<<1,l,mid,p,x);
if(p>mid) update(rt<<1|1,mid+1,r,p,x);
pushUp(rt,l,r);
}
} int query(int rt,int l,int r,int L,int R)
{
if(L<=l&&r<=R)
return len[rt];
if(R<=mid) return query(rt<<1,l,mid,L,R);
if(L>mid) return query(rt<<1|1,mid+1,r,L,R);
int li=query(rt<<1,l,mid,L,R);
int ri=query(rt<<1|1,mid+1,r,L,R);
int res=max(li,ri);
if(w[mid]<w[mid+1])
res=max(res,min(R,r1[rt<<1|1])-max(L,l1[rt<<1])+1);
return res;
} int main()
{
int T,n,m;
scanf("%d",&T);
while(T--)
{
scanf("%d%d",&n,&m);
for(int i=0;i<n;++i) scanf("%d",w+i); build(1,0,n-1);
int a,b;
char op[2];
while(m--)
{
scanf("%s%d%d",op,&a,&b);
if(op[0]=='Q'){
printf("%d\n",query(1,0,n-1,a,b));
}else if(op[0]=='U')
update(1,0,n-1,a,b);
}
}
return 0;
}

  

HDU-3308 LCIS(区间合并)的更多相关文章

  1. HDU 3308 LCIS (线段树区间合并)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=3308 题目很好懂,就是单点更新,然后求区间的最长上升子序列. 线段树区间合并问题,注意合并的条件是a[ ...

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

    题目链接:http://acm.hdu.edu.cn/showproblem.php? pid=3308 LCIS Time Limit: 6000/2000 MS (Java/Others)     ...

  3. HDU 3308 LCIS (经典区间合并)【线段树】

    <题目链接> 题目大意: 给你一段序列,对其进行两种操作,一是修改某个序号的点的值:二是查询某个区间的LCIS(最长上升子序列). 解题分析: 线段树区间合并的典型例题,用求某个区间的LC ...

  4. HDU 3308 LCIS (线段树&#183;单点更新&#183;区间合并)

    题意  给你一个数组  有更新值和查询两种操作  对于每次查询  输出相应区间的最长连续递增子序列的长度 基础的线段树区间合并  线段树维护三个值  相应区间的LCIS长度(lcis)  相应区间以左 ...

  5. HDU 3308 LCIS

    题意: U A B: 把第A个数变成BQ A B: 输出[A,B]最长连续上升子序列(注意是连续  相当于子串) 思路:单点更新 ,区间合并几下左边开头最小  和右边结束最大的两个数即可. #incl ...

  6. hdu 5720(贪心+区间合并)

    Wool Time Limit: 8000/4000 MS (Java/Others)    Memory Limit: 262144/262144 K (Java/Others)Total Subm ...

  7. HDU 3308 LCIS(线段树单点更新区间合并)

    LCIS Given n integers. You have two operations: U A B: replace the Ath number by B. (index counting ...

  8. (简单) HDU 3308 LCIS,线段树+区间合并。

    Problem Description Given n integers. You have two operations: U A B: replace the Ath number by B. ( ...

  9. HDU 3308 LCIS 线段树区间更新

    最近开始线段树一段时间了,也发现了不少大牛的博客比如HH大牛  ,小媛姐.这个题目是我在看HH大牛的线段树专题是给出的习题,(可以去他博客找找,真心推荐)原本例题是POJ3667 Hotel 这个题目 ...

  10. 线段树(区间维护):HDU 3308 LCIS

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

随机推荐

  1. android asyncTask 详解

    只看http://www.cnblogs.com/xiaoluo501395377/p/3430542.html  足以

  2. 动态加载DLL函数GetProcAddress错误

    GetLastError获取错误代码127,指代“找不到指定程序”. 解决: 转自:http://hi.baidu.com/violetwangy/item/c35b3b95ecf5374cf0421 ...

  3. 迭代器(Iterator)模式

    转自:http://blog.csdn.net/lilu_leo/article/details/7609496 概述      迭代器(Iterator)模式,又叫做游标(Cursor)模式.GOF ...

  4. Visual Studio 2015 预览版 - 支持跨平台开发Android/iOS应用程序(内置安卓模拟器)

    微软最近的惊人举动真多,对普通消费者Office 移动版宣布免费,对开发者也发布了完全免费的 VS2013 社区版! 不仅如此,就连 .Net 开发框架环境也竟然「开源」并且跨平台支持 Mac 及 L ...

  5. pager分页框架体会

    <pg:pager> 元素的属性中: maxPageItems说的是每页偏移量是多少,这个并不是说每一页显示多少,而是第二页比第一页来说,在第一页的尾部增加多少,第一页又被覆盖多少,是决定 ...

  6. VS2013开发Android App 环境搭建

    下载并安装vs2013,(安装时发现多了with blend,百度后有人说是设计师用版本,这是不对的,害我花费不少时间查找程序员用版本).我安装的是Microsoft Visual Studio Ul ...

  7. JavaScript之document对象使用

    1.document 对象常用的有三种: A.document.getElementById:通过html元素的Id,来获取html对象.适用于单个的html元素. B.document.getEle ...

  8. Ubuntu 14.10 下卸载MySQL

    前面讲了Mysql的简单安装方式,通过sudo apt-get install mysql-server 等脚本,安装之后如何卸载? 1 通过下面命令删除MySQL sudo apt-get auto ...

  9. VS2010编译Qt5.4.0静态库

    http://www.kavenblog.com/?p=375 1.Qt的跨平台十分优秀,但是在Windows上是还是会有许多问题,其中之一就是动态链接库的问题,Qt程序的发布必须带一个体积不小的DL ...

  10. 解决:未找到setenv命令

    在Ubuntu12.04中配置python环境变量:setenv PATH "$PATH:/usr/local/bin/python",提示未找到setenv命令. 为什么呢?这是 ...