luogu P4513 小白逛公园 (区间合并)
链接:https://www.luogu.org/problemnew/show/P4513
思路: 很基础的区间合并,开四个数组:
num: 区间数字的和
lsum:从左端点起最大连续字段和
rsum:从右端点起最大连续字段和
sum:区间最大连续字段和
然后按照以前合并的思路合并下就完事了。
好久没写区间合并的题。。还被卡了一阵子,属实弟弟
实现代码;
#include<bits/stdc++.h>
using namespace std;
#define lson l,mid,rt<<1
#define rson mid+1,r,rt<<1|1
#define ls rt<<1
#define rs rt<<1|1
const int M = 1e6+;
struct node{
int sum,lsum,num,rsum;
}t[M<<]; void pushup(int rt){
t[rt].num = t[ls].num + t[rs].num;
t[rt].sum = max(t[ls].sum,t[rs].sum);
t[rt].lsum = max(t[ls].lsum,t[rs].lsum+t[ls].num);
t[rt].rsum = max(t[rs].rsum,t[ls].rsum+t[rs].num);
t[rt].sum = max(t[rt].sum,t[ls].rsum+t[rs].lsum);
} void update(int p,int c,int l,int r,int rt){
if(l == r){
t[rt].sum = t[rt].lsum = t[rt].rsum = t[rt].num = c;
return ;
}
int mid = (l + r) >> ;
if(p <= mid) update(p,c,lson);
else update(p,c,rson);
pushup(rt);
} node query(int L,int R,int l,int r,int rt){
if(L<=l&&R>=r){
return t[rt];
}
int mid = (l + r) >> ;
if(R <= mid) return query(L,R,lson);
else if(L > mid) return query(L,R,rson);
else{
node t1 = query(L,R,lson),t2 = query(L,R,rson),ret;
ret.lsum = max(t1.lsum,t2.lsum+t1.num);
ret.rsum = max(t2.rsum,t1.rsum+t2.num);
ret.sum = max(max(t1.sum,t2.sum),t1.rsum+t2.lsum);
return ret;
}
} int main()
{
int n,q,x,y,op;
scanf("%d%d",&n,&q);
for(int i = ;i <= n;i ++)
scanf("%d",&x),update(i,x,,n,);
while(q--){
scanf("%d%d%d",&op,&x,&y);
if(op == ){
if(y < x) swap(x,y);
printf("%d\n",query(x,y,,n,).sum);
}
else{
update(x,y,,n,);
}
}
return ;
}
luogu P4513 小白逛公园 (区间合并)的更多相关文章
- 洛谷 P4513 小白逛公园-区间最大子段和-分治+线段树区间合并(单点更新、区间查询)
P4513 小白逛公园 题目背景 小新经常陪小白去公园玩,也就是所谓的遛狗啦… 题目描述 在小新家附近有一条“公园路”,路的一边从南到北依次排着nn个公园,小白早就看花了眼,自己也不清楚该去哪些公园玩 ...
- 线段树 || BZOJ1756: Vijos1083 小白逛公园 || P4513 小白逛公园
题面:小白逛公园 题解: 对于线段树的每个节点除了普通线段树该维护的东西以外,额外维护lsum(与左端点相连的最大连续区间和).rsum(同理)和sum……就行了 代码: #include<cs ...
- P4513 小白逛公园
题目背景 小新经常陪小白去公园玩,也就是所谓的遛狗啦… 题目描述 在小新家附近有一条“公园路”,路的一边从南到北依次排着 nnn 个公园,小白早就看花了眼,自己也不清楚该去哪些公园玩了. 一开始,小白 ...
- 洛谷P4513 小白逛公园
区间最大子段和模板题.. 维护四个数组:prefix, suffix, sum, tree 假设当前访问节点为cur prefix[cur]=max(prefix[lson],sum[lson]+pr ...
- P4513 小白逛公园 动态维护最大子段和
题目链接:https://www.luogu.org/problem/P4513 #include<iostream> #include<cstdio> #include< ...
- 洛谷P4513 小白逛公园 (线段树)
这道题看起来像是线段树和最大子段和的结合,但这里求最大子段和不用dp,充分利用线段树递归的优势来处理.个人理解:线段树相当于把求整个区间的最大子段和的问题不断划分为很多个小问题,容易解决小问题,然后递 ...
- 2018.07.23 洛谷P4513 小白逛公园(线段树)
传送门 线段树常规操作了解一下. 单点修改维护区间最大连续和. 对于一个区间,维护区间从左端点开始的连续最大和,从右端点开始的连续最大和,整个区间最大和,区间和. 代码如下: #include< ...
- P4513 小白逛公园 (线段树)
题目链接 Solution 线段树是一门比较刁钻的手艺... 此题我们需要维护 \(4\) 个变量: \(amx\) 代表当前节点的最大值. \(lmx\) 代表当前节点以左端点为起点的区间最大值. ...
- BZOJ 1756: Vijos1083 小白逛公园
题目 1756: Vijos1083 小白逛公园 Time Limit: 10 Sec Memory Limit: 64 MBSubmit: 856 Solved: 264[Submit][Sta ...
随机推荐
- 微信小程序填坑之旅(1)-app.js中用云开发获取openid,在其他页上用app.globaldata.openid获取为空
参考:小程序如何在其他页面监听globalData中值的变化?https://www.jianshu.com/p/8d1c4626f9a3 原因就是:app.js没执行完时,其他页已经onload了, ...
- springboot的@Configuration文件读取static静态文件
错误 正确
- effective c++ (四)
条款10:令operator=返回一个reference to *this 为了实现“连锁赋值”,赋值操作符必须返回一个reference指向操作符的左侧实参,这是你为classes实现赋值操作符时应 ...
- Intel Wireless AC9560 160MHZ 联网黄色感叹号的问题
Intel Wireless 开始支持5G设备了,AC9560 160MHZ可以工作在5G模式了.新入的设备驱动程序升级到了最新版本,发现联网出现“黄色感叹号”,DHCP的IP地址获取正常,从无线路由 ...
- [Luogu] 逛公园
https://www.luogu.org/problemnew/show/P3953 https://www.zybuluo.com/wsndy-xx/note/1134388 #include&l ...
- 平衡Dom总结
介绍: 新的项目中有些Dom元素需要和画布保持统一个适配比例 项目地址: 宝岛之光-台湾偶像剧 遇到的问题 H5项目使用Canvas, 适配采用保持宽高比例, 上下或者左右留白方式 在项目中有些Dom ...
- maven整合ssm框架
1.创建maven web工程 创建完成后,项目结构如下 2.项目配置文件 在pom.xml中添加SSM框架相关jar包的依赖关系,pom.xml代码如下 <?xml version=" ...
- Leetcode题目136.只出现一次的数字(简单)
---恢复内容开始--- 题目描述: 给定一个非空整数数组,除了某个元素只出现一次以外,其余每个元素均出现两次.找出那个只出现了一次的元素. 说明: 你的算法应该具有线性时间复杂度. 你可以不使用额外 ...
- ES节点分析
ES集群概念 集群 一个集群cluster由一个或者多个节点组成,具有相同的cluster.name,协同工作,分项数据和负载. 当有新的节点加入或者删除了一个节点时,集群回感知到并能够平衡数据. E ...
- java日期大小比较
之前有面试到两个日期的大小比较方式,现在整理一下几种方法. 例子: String beginTime=new String("2017-06-09 10:22:22"); S ...