[luogu4513]小白逛公园
题目描述
在小新家附近有一条“公园路”,路的一边从南到北依次排着n个公园,小白早就看花了眼,自己也不清楚该去哪些公园玩了。
一开始,小白就根据公园的风景给每个公园打了分-.-。小新为了省事,每次遛狗的时候都会事先规定一个范围,小白只可以选择第a个和第b个公园之间(包括a、b两个公园)选择连续的一些公园玩。小白当然希望选出的公园的分数总和尽量高咯。同时,由于一些公园的景观会有所改变,所以,小白的打分也可能会有一些变化。
那么,就请你来帮小白选择公园吧。
分析
必须要清楚,线段树中\(pushup\)操作只能是从儿子节点传递到父亲节点。如果要A掉这道题,绝对不能用线段树父亲节点来更新自己的任何值,不然会错到飞起。
那么回到这道题目,我们记录\(lm,rm,s,res\),分别表示从区间左端开始的最大子段和,从区间右边开始的最大子段和,区间和,和答案。
那么我们每次考虑的思路都是通过mid和不通过mid来合并两个节点的答案。
ac代码
#include <bits/stdc++.h>
#define ll long long
#define ms(a, b) memset(a, b, sizeof(a))
#define inf 0x3f3f3f3f
#define N 500005
using namespace std;
template <typename T>
inline void read(T &x) {
x = 0; T fl = 1;
char ch = 0;
while (ch < '0' || ch > '9') {
if (ch == '-') fl = -1;
ch = getchar();
}
while (ch >= '0' && ch <= '9') {
x = (x << 1) + (x << 3) + (ch ^ 48);
ch = getchar();
}
x *= fl;
}
struct segment_tree {
#define ls (nod<<1)
#define rs (nod<<1|1)
#define mid ((l+r)>>1)
struct node {
int s, lm, rm, l, r, res;
}tr[N << 2];
void pushup(int nod) {
tr[nod].s = tr[ls].s + tr[rs].s;
tr[nod].lm = max(tr[ls].lm, tr[rs].lm + tr[ls].s);
tr[nod].rm = max(tr[rs].rm, tr[ls].rm + tr[rs].s);
tr[nod].res = max(max(tr[rs].res, tr[ls].res), tr[ls].rm + tr[rs].lm);
}
void build(int l, int r, int nod, int *a) {
tr[nod].l = l, tr[nod].r = r;
if (l == r) {
tr[nod].lm = tr[nod].rm = tr[nod].res = tr[nod].s = a[l];
return;
}
build(l, mid, ls, a);
build(mid + 1, r, rs, a);
pushup(nod);
}
void update_point(int nod, int k, int v) {
int l = tr[nod].l, r = tr[nod].r;
if (l == r) {
tr[nod].lm = tr[nod].res = tr[nod].rm = tr[nod].s = v;
return;
}
if (k <= mid) update_point(ls, k, v);
else update_point(rs, k, v);
pushup(nod);
}
node query(int nod, int ql, int qr) {
int l = tr[nod].l, r = tr[nod].r;
if (ql <= l && r <= qr)
return tr[nod];
if (qr <= mid) return query(ls, ql, qr);
else if (ql > mid) return query(rs, ql, qr);
else {
node tmp, tmp1 = query(ls, ql, mid), tmp2 = query(rs, mid + 1, qr);
tmp.lm = max(tmp1.lm, tmp1.s + tmp2.lm);
tmp.rm = max(tmp2.rm, tmp2.s + tmp1.rm);
tmp.res = max(max(tmp1.res, tmp2.res), tmp1.rm + tmp2.lm);
return tmp;
}
}
}tr;
int a[N];
int n, m;
int main() {
read(n); read(m);
for (int i = 1; i <= n; i ++) read(a[i]);
tr.build(1, n, 1, a);
while (m--) {
int opt, x, y;
read(opt); read(x); read(y);
if (opt == 1) {
if (x > y) swap(x, y);
printf("%d\n", tr.query(1, x, y).res);
}
else tr.update_point(1, x, y);
}
return 0;
}
[luogu4513]小白逛公园的更多相关文章
- [vijos P1083] 小白逛公园
不知怎地竟有种错觉此题最近做过= =目测是类似的?那道题貌似是纯动归? 本来今晚想做两道题的,一道是本题,一道是P1653疯狂的方格取数或NOI08 Employee,看看现在的时间目测这个目标又达不 ...
- Bzoj 1756: Vijos1083 小白逛公园 线段树
1756: Vijos1083 小白逛公园 Time Limit: 10 Sec Memory Limit: 64 MBSubmit: 1021 Solved: 326[Submit][Statu ...
- BZOJ 1756: Vijos1083 小白逛公园
题目 1756: Vijos1083 小白逛公园 Time Limit: 10 Sec Memory Limit: 64 MBSubmit: 856 Solved: 264[Submit][Sta ...
- JDOJ-P1260 VIJOS-P1083 小白逛公园
首先,在这里给大家推荐一个网站,https://neooj.com:8082,这是我母校的网站 言归正传,题目描述 VIJOS-P1083 小白逛公园 Time Limit: 1 Sec Memor ...
- 线段树 || BZOJ1756: Vijos1083 小白逛公园 || P4513 小白逛公园
题面:小白逛公园 题解: 对于线段树的每个节点除了普通线段树该维护的东西以外,额外维护lsum(与左端点相连的最大连续区间和).rsum(同理)和sum……就行了 代码: #include<cs ...
- 洛谷 P4513 小白逛公园-区间最大子段和-分治+线段树区间合并(单点更新、区间查询)
P4513 小白逛公园 题目背景 小新经常陪小白去公园玩,也就是所谓的遛狗啦… 题目描述 在小新家附近有一条“公园路”,路的一边从南到北依次排着nn个公园,小白早就看花了眼,自己也不清楚该去哪些公园玩 ...
- vijos1083:小白逛公园
小白逛公园 描述 小新经常陪小白去公园玩,也就是所谓的遛狗啦…在小新家附近有一条“公园路”,路的一边从南到北依次排着n个公园,小白早就看花了眼,自己也不清楚该去哪些公园玩了. 一开始,小白就根据公园的 ...
- 小白逛公园加强版(park)
小白逛公园加强版(park) 题目描述 小新经常陪小白去公园玩,也就是所谓的遛狗啦--在小新家附近有n个公园,这些公园通过一些路径相连,并保证每两个公园之间有且仅有一条通路相连(也就是说这是一棵树), ...
- TYVJ1427 小白逛公园
时间: 1000ms / 空间: 131072KiB / Java类名: Main 描述 小新经常陪小白去公园玩,也就是所谓的遛狗啦…在小新家附近有一条“公园路”,路的一边从南到北依次排着n个 ...
随机推荐
- Bluedroid 函数分析:bta_dm_gattc_register
我们先来看看在bluedroid 里面有多少地方调用到这里: 可以看出除了 它自己声明的地方,有三处 调用到这个函数. 一处是 进行discovery,一处是进行search的时候,还有一次是bta_ ...
- Linux常用命令行
实时查看日志runtime.log最后100行 tail -f -n 100 runtime.log
- centos单机安装nginx、gitlab、nexus、mysql共存
思路就是不同系统设不同端口号,通过nginx做反向代理绑定不同域名. nginx 安装 1.安装pcre软件包(使nginx支持http rewrite模块)yum install -y pcreyu ...
- Jmeter(三十二)_搭建本地接口自动化环境
我们在学习接口自动化的时候,最理想的状态是在公司有项目可以操作.大部分时候我们并没有可以练习的项目,因此练习接口无从谈起,只能找一些开放的api来练一练,但是这样并不能提高我们的技术.因此我们需要搭建 ...
- Linux Namespace : IPC
IPC namespace 用来隔离 System V IPC 对象和 POSIX message queues.其中 System V IPC 对象包含共享内存.信号量和消息队列,笔者在<Sy ...
- Ceph分布式存储-运维操作笔记
一.Ceph简单介绍1)OSDs: Ceph的OSD守护进程(OSD)存储数据,处理数据复制,恢复,回填,重新调整,并通过检查其它Ceph OSD守护程序作为一个心跳 向Ceph的监视器报告一些检测信 ...
- GIthub地址
https://github.com/cuibaoxue/Text1
- FZU软工实践–团队成员交换交接情况
0.前言 本次交接主要是为了之后Beta冲刺工作可以更加顺利而进行的.因为我跟其他队友交互不够方便,而且我们项目当前比较缺做前端的人员,后端功能已基本实现.所以我换出来了.希望大家可以顺顺利利做完一步 ...
- Nginx rewrite模块深入浅出详解
rewrite模块(ngx_http_rewrite_module) nginx通过ngx_http_rewrite_module模块支持url重写.支持if条件判断,但不支持else.另外该模块需要 ...
- [日常工作] Inspur 服务器安装ESXi的简单过程
1. 公司里面使用虚拟化来进行功能测试 性能测试, 现阶段和之前主要是用虚拟机来搞. 前期用过hyperV 但是感觉 没有SystemCenter的VMM的授权比较难搞一些. 所以还是用ESXi的多了 ...