题目大意:给一个整数序列,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. 读者写者问题(有bug 后续更改)

    与上一篇<秒杀多线程第十篇 生产者消费者问题>的生产者消费者问题一样,读者写者也是一个非常著名的同步问题.读者写者问题描述非常简单,有一个写者很多读者,多个读者可以同时读文件,但写者在写文 ...

  2. 《Java程序性能优化:让你的Java程序更快、更稳定》

    Java程序性能优化:让你的Java程序更快.更稳定, 卓越网更便宜,不错的书吧

  3. 封装定制的Kali Live ISO

    打造专属的Kali ISO – 简介 封装定制的Kali ISO很简单,很有趣,很有意义.你可以用Debian的live-build脚本对Kali ISO进行全面的配置.这些脚本以一系列配置文件的方式 ...

  4. php大力力 [026节] php开发状态要随时做好整理工作

    php大力力 [026节]  php开发状态要随时做好整理工作: 1.整理了开发目录,以及文件命名: 2.做了各个页面的快捷方式: 3.把浏览器safari的很多没来得及消化的页面链接,写入了我的在线 ...

  5. 【Leetcode】 LRU Cache实现

    Design and implement a data structure for Least Recently Used (LRU) cache. It should support the fol ...

  6. PHP中的错误处理和异常处理

    错误处理:    1.语法错误    2.运行时的错误    3.逻辑错误 错误报告:        错误E_ERROR        警告E_WARNING        注意E_NOTICE 开发 ...

  7. ERP权限系统(七)

    添加链接权限的字段: //权限管理 n.Target = "MainFrame"; //折叠 TreeView1.Nodes.Add(n); n.Expanded = false;

  8. Spring注解和配置方式

    Spring提供了一个org.springframework.beans.factory.FactoryBean工厂类接口,用户可以通过实现该接口定制实例化Bean的逻辑. 从Spring3.0开始, ...

  9. 自定义NavigationBar

    [self.navigationController.navigationBarsetHidden:YES]; CGRect screenRect = [[UIScreen mainScreen] b ...

  10. 10、SQL基础整理(约束2)

    约束 除主键约束.外键约束外 唯一约束(主键列.索引列的候选索引)   设计---右键---索引/键---需要修改的列----是唯一的----忽略重复键 代码方式: cid  varchar (20) ...