HDU 3308 LCIS (经典区间合并)【线段树】
<题目链接>
题目大意:
给你一段序列,对其进行两种操作,一是修改某个序号的点的值;二是查询某个区间的LCIS(最长上升子序列)。
解题分析:
线段树区间合并的典型例题,用求某个区间的LCIS时,需要比较三个值,一是左区间的LCIS,二是右区间的LCIS,三是左右子区间合并的LCIS。最重要的是第三点如何实现,实现第三点需要维护一个最长后缀上升子序列和最长前缀上升子序列,总之,相对于一般的线段树,区间合并需要对Pushup()函数进行一些改动,query()的时候也要记得对三种情况进行讨论。
#include <cstdio>
#include <cstring>
#include <iostream>
#include <algorithm>
using namespace std;
const int siz=;
int a[siz],sum[siz<<],lsum[siz<<],rsum[siz<<]; void pushup(int rt,int l,int r) { //区间合并,更新该节点对应的最长上升子序列和最长前、后缀
lsum[rt]=lsum[rt<<]; //最长前缀
rsum[rt]=rsum[rt<<|]; //最长后缀
sum[rt]=max(sum[rt<<],sum[rt<<|]);
/*-- 先更新该节点需要维护的三个值 --*/ int m=(l+r)>>;
if(a[m]<a[m+]){ //如果左右子区间的LCIS能够合并,那么就进一步更新这三个点 if(lsum[rt<<]==(m-l+)) //如果左子区间的最长前缀==左子区间长度
lsum[rt]+=lsum[rt<<|]; //那么该节点的最长前缀除左子区间的最长前缀以外,还要加上右子区间的最长前缀
if(rsum[rt<<|]==(r-m)) //如果右子区间的最长后缀==右子区间长度
rsum[rt]+=rsum[rt<<]; //那么该节点的最长后缀除右子区间的最长后缀外,还要加上左子区间的最长后缀
/*-- 更新rt节点对应区间的最长前、后缀 --*/ sum[rt]=max(sum[rt],rsum[rt<<]+lsum[rt<<|]);
//更新rt节点对应区间的最长上升子序列
}
}
void build(int l,int r,int rt){
if(l==r){ //注意这里的初始化
sum[rt]=;
lsum[rt]=rsum[rt]=;
return;
}
int m=(l+r)>>;
build(l,m,rt<<);
build(m+,r,rt<<|);
pushup(rt,l,r);
}
void update(int loc,int val,int l,int r,int rt){ //单点更新
if(l==r){
a[l]=val;
return;
}
int m=(l+r)>>;
if(loc<=m)
update(loc,val,l,m,rt<<);
else
update(loc,val,m+,r,rt<<|);
pushup(rt,l,r);
}
int query(int L,int R,int l,int r,int rt){
if(L<=l&&r<=R)
return sum[rt];
int m=(l+r)>>;
int ans=; //注意这里ans初始化为1 /*-- 答案一共三种可能,在左区间或右区间或横跨两个区间 --*/
if(L<=m) //左、右区间的LCIS
ans=max(ans,query(L,R,l,m,rt<<));
if(R>m)
ans=max(ans,query(L,R,m+,r,rt<<|)); if(L<=m&&R>=m&&a[m]<a[m+]) //横跨左右两个子区间的情况
ans=max(ans,min(m-L+,rsum[rt<<])+min(R-m,lsum[rt<<|])); //rsum代表区间最长后缀、lsum为区间最长前缀
return ans;
} int main(){ //lsum为区间左端点开始长度
char c; //rsum为区间右端点开始长度
int t,n,m; //sum为区间最长长度
scanf("%d",&t);
while(t--){
scanf("%d%d",&n,&m);
for(int i=;i<=n;i++)
scanf("%d",&a[i]);
build(,n,);
while(m--){
int u,v;
cin>>c>>u>>v;
if(c=='Q'){
u++,v++; //因为题目是从0开始编号
printf("%d\n",query(u,v,,n,));
}
else{
u++;
update(u,v,,n,);
}
}
}
return ;
}
2018-09-11
HDU 3308 LCIS (经典区间合并)【线段树】的更多相关文章
- BZOJ 2243:染色(树链剖分+区间合并线段树)
[SDOI2011]染色Description给定一棵有n个节点的无根树和m个操作,操作有2类:1.将节点a到节点b路径上所有点都染成颜色c:2.询问节点a到节点b路径上的颜色段数量(连续相同颜色被认 ...
- HDU 1540 区间合并线段树
题目大意: 就是给定一堆位置,进行删除还原,最后找到 t 位置上的最大连续位置 #include <cstdio> #include <cstring> #include &l ...
- HDU 3308 LCIS (线段树·单点更新·区间合并)
题意 给你一个数组 有更新值和查询两种操作 对于每次查询 输出相应区间的最长连续递增子序列的长度 基础的线段树区间合并 线段树维护三个值 相应区间的LCIS长度(lcis) 相应区间以左 ...
- HDU 5029 Relief grain(离线+线段树+启发式合并)(2014 ACM/ICPC Asia Regional Guangzhou Online)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=5029 Problem Description The soil is cracking up beca ...
- hdu 5700区间交(线段树)
区间交 Time Limit: 8000/4000 MS (Java/Others) Memory Limit: 65536/65536 K (Java/Others)Total Submiss ...
- hdu 5274 Dylans loves tree(LCA + 线段树)
Dylans loves tree Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 131072/131072 K (Java/Othe ...
- 【BZOJ4653】【NOI2016】区间(线段树)
[BZOJ4653][NOI2016]区间(线段树) 题面 BZOJ 题解 \(NOI\)良心送分题?? 既然是最大长度减去最小长度 莫名想到那道反复减边求最小生成树 从而求出最小的比值 所以这题的套 ...
- BZOJ_4653_[Noi2016]区间_线段树+离散化+双指针
BZOJ_4653_[Noi2016]区间_线段树+离散化+双指针 Description 在数轴上有 n个闭区间 [l1,r1],[l2,r2],...,[ln,rn].现在要从中选出 m 个区间, ...
- xdoj-1324 (区间离散化-线段树求区间最值)
思想 : 1 优化:题意是覆盖点,将区间看成 (l,r)转化为( l-1,r) 覆盖区间 2 核心:dp[i] 覆盖从1到i区间的最小花费 dp[a[i].r]=min (dp[k])+a[i]s; ...
随机推荐
- web的分页方法
web分页的三种方式,闲来无事总结一下. 1.使用前端表格插件进行分页 例如用bootstrap的拓展table组件,注意设置其分页属性时设置为"client", 即是 sideP ...
- Jquery如何获取iframe里面body的html呢?
如果是自己网页的话,可以这样,$("iframe").contents().find("body").html();意思是,获取iframe里面页面body的内 ...
- python之dict与set实现原理之hash算法
理解不透彻,下回分解 http://www.cnblogs.com/pengsixiong/p/5326893.html https://blog.csdn.net/zhao_crystal/arti ...
- 单击列表行前边的checkbox被选中,再单击,取消选中
需求描述:单击datatabl的一行数据,前边的checkbox被勾选上,再次点击,选中取消,第一次碰到这种需求,不过呢也很实用,简单记录一下 代码: //html代码<tr class=&qu ...
- 【ssh】端口转发
来源:https://www.ibm.com/developerworks/cn/linux/l-cn-sshforward/ 非常非常好用,可以通过跳板解决两台服务器无法连接的问题 第一部分 概述 ...
- JSTL 标准标签库 (JavaServer Pages Standard Tag library, JSTL)
JSP标准标签库(JavaServer Pages Standard Tag Library,JSTL)是一个定制标签库的集合,用来解决 像遍历Map或集合.条件测试.XML处理,甚至数据 库访问和数 ...
- laravel 注入那点事
public function delete(Group $groupId, Post $postId) { $postId->delete(); return response()->j ...
- java-HTML&javaSkcript&CSS&jQuery&ajax
CSS 伪装 1.<style>a;link{color:#000000} a:visited{color:#000000; a.:hover{color:#FF00FF} a:acti ...
- QuerySet中添加Extra进行SQL查询
select参数接受一个映射到SQL的字符串标识字典,让你可以根据SQL select子句里的选择进行对模型实例添加属性,或者查询. from blog.models import BlogPost& ...
- bzoj2200拓扑排序+最短路+联通块
自己写的不知道哪里wa了,明明和网上的代码差不多.,. /* 给定一张图,有的边是无向边,有的是有向边,有向边不会出现在环中,且有可能是负权值 现在给定起点s,求出s到其余所有点的最短路长度 任何存在 ...