HDU-3308 LCIS(区间合并)
题目大意:给一个整数序列,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(区间合并)的更多相关文章
- HDU 3308 LCIS (线段树区间合并)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=3308 题目很好懂,就是单点更新,然后求区间的最长上升子序列. 线段树区间合并问题,注意合并的条件是a[ ...
- hdu 3308 LCIS(线段树区间合并)
题目链接:http://acm.hdu.edu.cn/showproblem.php? pid=3308 LCIS Time Limit: 6000/2000 MS (Java/Others) ...
- HDU 3308 LCIS (经典区间合并)【线段树】
<题目链接> 题目大意: 给你一段序列,对其进行两种操作,一是修改某个序号的点的值:二是查询某个区间的LCIS(最长上升子序列). 解题分析: 线段树区间合并的典型例题,用求某个区间的LC ...
- HDU 3308 LCIS (线段树·单点更新·区间合并)
题意 给你一个数组 有更新值和查询两种操作 对于每次查询 输出相应区间的最长连续递增子序列的长度 基础的线段树区间合并 线段树维护三个值 相应区间的LCIS长度(lcis) 相应区间以左 ...
- HDU 3308 LCIS
题意: U A B: 把第A个数变成BQ A B: 输出[A,B]最长连续上升子序列(注意是连续 相当于子串) 思路:单点更新 ,区间合并几下左边开头最小 和右边结束最大的两个数即可. #incl ...
- hdu 5720(贪心+区间合并)
Wool Time Limit: 8000/4000 MS (Java/Others) Memory Limit: 262144/262144 K (Java/Others)Total Subm ...
- HDU 3308 LCIS(线段树单点更新区间合并)
LCIS Given n integers. You have two operations: U A B: replace the Ath number by B. (index counting ...
- (简单) HDU 3308 LCIS,线段树+区间合并。
Problem Description Given n integers. You have two operations: U A B: replace the Ath number by B. ( ...
- HDU 3308 LCIS 线段树区间更新
最近开始线段树一段时间了,也发现了不少大牛的博客比如HH大牛 ,小媛姐.这个题目是我在看HH大牛的线段树专题是给出的习题,(可以去他博客找找,真心推荐)原本例题是POJ3667 Hotel 这个题目 ...
- 线段树(区间维护):HDU 3308 LCIS
LCIS Time Limit: 6000/2000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)Total Submis ...
随机推荐
- Register-SPWorkflowService 远程服务器返回错误: (404) 未找到
博客地址:http://blog.csdn.net/foxdave 当想创建一个SharePoint 2013 工作流的时候,打开SharePoint 2013 Designer(一下简称SPD),发 ...
- Javascript计数器
<!DOCTYPE HTML><html><head><meta http-equiv="Content-Type" content=&q ...
- 《J2EE,J2SE,J2ME》
J2EE(Java EE)是做企业级应用的.比如,163邮箱,比如某公司的管理系统 J2SE(Java SE)就是Java语言的标准版本,类似于C++,主要做桌面软件,比如Eclipse,MyEcli ...
- 支撑向量机(SVM)
转载自http://blog.csdn.net/passball/article/details/7661887,写的很好,虽然那人也是转了别人的做了整理(最原始文章来自http://www.blog ...
- explain分析查询
参考以下文章,在此非常感谢原作者 explain分析查询
- System.out.println()输出到指定文件里
public static void main(String[] args) throws Exception{ String str = "abcd"; PrintStream ...
- hdoj-2019
#include "stdio.h"void sort(int number[],int n,int m);int main(){ int n,m,i,number[100]; s ...
- 解决办法:在指定的 DSN 中,驱动程序和应用程序之间的体系结构不匹配 问题解决 SQLSTATE=IM014
环境:64位win7,64位MySql 解决办法:32为和64位ODBC都安装上即可.
- javascript笔记1-基本概念
关键字: 变量: function test(){ message = 'hi'; //不加var,表示全局变量:加var,表示局部变量 } 数据类型: 总共有五种基本数据类型:Undefined.N ...
- Ubuntu安装samba的问题
问题: root@ubuntu:~# apt-get install samba 正在读取软件包列表... 完成 正在分析软件包的依赖关系树 正在读取状态信息... 完成 有一些软件包无法被安装.如果 ...