Acwing 245.你能回答这些问题吗
题目描述
给定长度为N的数列A,以及M条指令,每条指令可能是以下两种之一:
1、“1 x y”,查询区间 [x,y] 中的最大连续子段和,即 maxx≤l≤r≤y{∑ri=lA[i]}。
2、“2 x y”,把 A[x] 改成 y。
对于每个查询指令,输出一个整数表示答案。
输入格式
第一行两个整数N,M。
第二行N个整数A[i]。
接下来M行每行3个整数k,x,y,k=1表示查询(此时如果x>y,请交换x,y),k=2表示修改。
输出格式
对于每个查询指令输出一个整数表示答案。
每个答案占一行。
数据范围
N≤500000,M≤100000
输入样例:
5 3
1 2 -3 4 5
1 2 3
2 2 -1
1 3 2
输出样例:
2
-1
时/空限制:
1s / 64MB
rt。
一道挺难的线段树题。
#include<bits/stdc++.h>
#define int long long
using namespace std;
const int maxn = 5e5 + 5;
struct seg{
int ans, sum, l, r, L, R;
#define ans(p) t[p].ans
#define sum(p) t[p].sum
#define l(p) t[p].l
#define r(p) t[p].r
#define L(p) t[p].L
#define R(p) t[p].R
}t[maxn << 2];
int num[maxn];
void build(int p, int l, int r){
l(p) = l; r(p) = r;
if(l == r){
sum(p) = ans(p) = L(p) = R(p) = num[l];
return ;
}
int mid = l + r >> 1;
build(p << 1, l, mid);
build(p << 1 | 1 , mid + 1, r);
sum(p) = sum(p << 1) + sum(p << 1 | 1);
L(p) = max(L(p << 1), sum(p << 1) + L(p << 1 | 1));
R(p) = max(R(p << 1 | 1), sum(p << 1 | 1) + R(p << 1));
int sondata = max(ans(p << 1), ans(p << 1 | 1));
ans(p) = max(sondata, L(p << 1 | 1) + R(p << 1));
}
void change(int p, int d, int k){
if(d < l(p) || d > r(p))
return ;
if(l(p) == r(p)){
sum(p) = ans(p) = L(p) = R(p) = k;
return ;
}
change(p << 1, d, k);
change(p << 1 | 1, d, k);
sum(p) = sum (p << 1) + sum (p << 1 | 1);
L(p) = max(L(p << 1), sum(p << 1) + L(p << 1 | 1));
R(p) = max(R(p << 1 | 1), sum(p << 1 | 1) + R(p << 1));
int sondata = max(ans(p << 1), ans(p << 1 | 1));
ans(p) = max(sondata, L(p << 1 | 1) + R(p << 1));
}
seg query(int p ,int l, int r){
if(l <= l(p) && r(p) <= r){
return t[p];
}
seg lson, rson, res;
int mid = l(p) + r(p) >> 1, val = -1e9;
lson = (seg){val, val, 0, 0, val, val};
rson = lson;
res.sum = 0;
if(l <= mid){
lson = query(p << 1, l, r);
res.sum += lson.sum;
}
if(mid < r){
rson = query(p << 1 | 1, l, r);
res.sum += rson.sum;
}
int answer = max(lson.ans, rson.ans);
res.ans = max(answer, lson.R + rson.L);
res.L = max(lson.L, lson.sum + rson.L);
res.R = max(rson.R, rson.sum + lson.R);
if(l > mid)
res.L = max(res.L, rson.L);
if(r <= mid)
res.R = max(res.R, lson.R);
return res;
}
signed main(){
int n, m;
scanf("%lld%lld", &n, &m);
for(int i = 1;i <= n;i ++)
scanf("%lld", &num[i]);
build(1, 1, n);
//printf ("[TESTDATA] the root rlen answer is %d. \n", R(3));
for(int i = 1;i <= m;i ++){
int x, y, z;
scanf("%lld%lld%lld", &x, &y, &z);
if(x == 1){
if(y > z)
swap(y, z);
printf("%lld\n", query(1, y, z).ans);
} else {
change(1, y, z);
}
}
return 0;
}
Acwing 245.你能回答这些问题吗的更多相关文章
- AcWing:245. 你能回答这些问题吗(线段树最大子段和)
给定长度为N的数列A,以及M条指令,每条指令可能是以下两种之一: 1.“1 x y”,查询区间 [x,y] 中的最大连续子段和,即 maxx≤l≤r≤ymaxx≤l≤r≤y{∑ri=lA[i]∑i=l ...
- ACwing 你能回答这些问题吗(线段树求最大连续字段和)
给定长度为N的数列A,以及M条指令,每条指令可能是以下两种之一: 1.“1 x y”,查询区间 [x,y] 中的最大连续子段和,即 maxx≤l≤r≤ymaxx≤l≤r≤y{∑ri=lA[i]∑i=l ...
- AcWing 244. 谜一样的牛 (树状数组+二分)打卡
题目:https://www.acwing.com/problem/content/245/ 题意:有n只牛,现在他们按一种顺序排好,现在知道每只牛前面有几只牛比自己低,牛的身高是1-n,现在求每只牛 ...
- AcWing 229. 新NIM游戏 (线性基+博弈论)打卡
题目:https://www.acwing.com/problem/content/description/231/ 题意:给出n堆石子,然后第一回合,A玩家可以随便拿多少堆石子,第二回合B玩家随便拿 ...
- acwing 239. 奇偶游戏 并查集
地址 https://www.acwing.com/problem/content/241/ 小A和小B在玩一个游戏. 首先,小A写了一个由0和1组成的序列S,长度为N. 然后,小B向小A提出了M个 ...
- 回答阿里社招面试如何准备,顺便谈谈对于Java程序猿学习当中各个阶段的建议
引言 其实本来真的没打算写这篇文章,主要是LZ得记忆力不是很好,不像一些记忆力强的人,面试完以后,几乎能把自己和面试官的对话都给记下来.LZ自己当初面试完以后,除了记住一些聊过的知识点以外,具体的内容 ...
- 每日一问:面试结束时面试官问"你有什么问题需要问我呢",该如何回答?
面试结束时面试官问"你有什么问题需要问我呢",该如何回答?
- python爬虫beta版之抓取知乎单页面回答(low 逼版)
闲着无聊,逛知乎.发现想找点有意思的回答也不容易,就想说要不写个爬虫帮我把点赞数最多的给我搞下来方便阅读,也许还能做做数据分析(意淫中--) 鉴于之前用python写爬虫,帮运营人员抓取过京东的商品品 ...
- 用python+selenium抓取知乎今日最热和本月最热的前三个问题及每个问题的首个回答并保存至html文件
抓取知乎今日最热和本月最热的前三个问题及每个问题的首个回答,保存至html文件,该html文件的文件名应该是20160228_zhihu_today_hot.html,也就是日期+zhihu_toda ...
随机推荐
- python如何连接数据库操作?
1.首先导入模块(提前pip安装) import pymysql ; 2.打开数据库连接 db = pymysql.connect("localhost", "us ...
- Luogu P4546 [THUWC2017]在美妙的数学王国中畅游
题意 题意奇奇怪怪,这里就不写了. \(\texttt{Data Range:}1\leq n\leq 10^5,1\leq m\leq 2\times 10^5\) 题解 为什么你们都是卡在数学方面 ...
- nextInt()和nextLine()连用报错
当nextInt(),next(),nextDouble(),nextFloat()方法与nextLine()连用并放在nextLine()前面时,会出现下面的错误: Exception in thr ...
- linux查找大文件及详细问题
查询大文件du -h --max-depth=1 查询指定目录下面的文件大小du -h --max-depth=1 /path 使用find命令查找大于200M文件 find / -type f -s ...
- Java入门(5)
阅读书目:Java入门经典(第7版) 作者:罗格斯·卡登海德 protected变量只能在其所在的类,该类的子类,以及同一个包里的其他类中使用.包是一组用于完成相同目标的相关类. private变量只 ...
- css 兼容性总结
1.就是ie6双倍边距的问题,在使用了float的情况下,不管是向左还是向右都会出现双倍,最简单的解决方法就是用display:inline;加到css里面去. 2.文字本身的大小不兼容.同样是fon ...
- 【SpringCloud】08.客户端负载均衡器:Ribbon
客户端负载均衡器:Ribbon Ribbon实现软负载均衡核心: 服务发现 :依据服务的名字,把该服务下所有的实例都找出来 服务选择规则:依据规则策略,如果从多个实例中,选出有效的服务 服务监听:检测 ...
- layui系列学习第一天
新开一个博客系列 记录下layui学习过程及感受 今天受到很大的打击 ...希望 自己能坚持做好 到1.12号可以完成这个博客 一.基础说明 layui css 命名规范:1.layui-模块名- ...
- Assert类的静态方法
五:常用断言 在NUnit中,断言是单元测试的核心.NUnit提供了一组丰富的断言,这些断言是Assert类的静态方法.如果一个断言失败,方法的调用不会返回值,并且会报告一个错误.如果一个测试包含多个 ...
- Git项目管理出现 .gitignore文件不起作用的解决
在git管理项目的代码过程中总会有需要忽略的目录或者文件,比如编译过程中产生的目录和文件,这时候就需要 .gitignore来进行目录或文件的忽略了. 如果没有 .gitignore文件,可以自己手工 ...