题目链接

http://uoj.ac/problem/164

题解

神仙线段树题。
首先赋值操作可以等价于减掉正无穷再加上\(x\).
假设某个位置从前到后的操作序列是: \(x_1,x_2,...,x_k\)
那么则有: 当前值就是该序列的最大后缀和,历史最大值就是该序列的最大子段和!
然后如果把最大子段和定义加法,那么就变成了区间加单点查询。
直接线段树维护即可,时间复杂度\(O(n\log n)\).
(好吧,其实似乎把赋值看做减去正无穷再加\(x\)似乎是可以被卡爆long long的……但是它确实过了)

代码

#include<bits/stdc++.h>
#define llong long long
using namespace std;const int N = 5e5;
void updsum(llong &x,llong y) {x = x>=y?x:y;}
struct Data
{llong s,ls,rs,lrs;Data() {}Data(llong x) {lrs = x; x = x<0ll?0ll:x; s = ls = rs = x;}Data(llong _s,llong _ls,llong _rs,llong _lrs):s(_s),ls(_ls),rs(_rs),lrs(_lrs) {}bool operator ==(const Data &arg) const {return s==arg.s&&ls==arg.ls&&rs==arg.rs&&lrs==arg.lrs;}
};
Data operator +(const Data &arg1,const Data &arg2)
{Data ret(0,0,0,0);ret.lrs = arg1.lrs+arg2.lrs;ret.ls = max(arg1.ls,arg1.lrs+arg2.ls);ret.rs = max(arg1.rs+arg2.lrs,arg2.rs);ret.s = max(max(arg1.s,arg2.s),arg1.rs+arg2.ls);return ret;
}
llong a[N+3];
int n,q;struct SegmentTree
{Data sgt[(N<<2)+3];void pushdown(int u){sgt[u<<1] = sgt[u<<1]+sgt[u];sgt[u<<1|1] = sgt[u<<1|1]+sgt[u];sgt[u] = Data(0);}void build(int u,int le,int ri,llong a[]){if(le==ri) {sgt[u] = Data(a[le]); return;}int mid = (le+ri)>>1;build(u<<1,le,mid,a); build(u<<1|1,mid+1,ri,a);}void add(int u,int le,int ri,int lb,int rb,llong x){if(le>=lb && ri<=rb) {sgt[u] = sgt[u]+Data(x); return;}pushdown(u);int mid = (le+ri)>>1;if(lb<=mid) add(u<<1,le,mid,lb,rb,x);if(rb>mid) add(u<<1|1,mid+1,ri,lb,rb,x);}llong query(int u,int le,int ri,int pos,int typ) //1:cur 2:hist{if(le==ri) {return typ==1?sgt[u].rs:sgt[u].s;}pushdown(u);int mid = (le+ri)>>1;if(pos<=mid) return query(u<<1,le,mid,pos,typ);else return query(u<<1|1,mid+1,ri,pos,typ);}
} sgt;int main()
{scanf("%d%d",&n,&q); llong cur = 0ll;for(int i=1; i<=n; i++) scanf("%lld",&a[i]),cur = max(cur,a[i]);sgt.build(1,1,n,a);while(q--){int opt; scanf("%d",&opt);if(opt==1||opt==2){int l,r; llong x; scanf("%d%d%lld",&l,&r,&x); if(opt==1) cur+=x; if(opt==2) x=-x;sgt.add(1,1,n,l,r,x);}else if(opt==3){int l,r; llong x; scanf("%d%d%lld",&l,&r,&x);sgt.add(1,1,n,l,r,-cur); sgt.add(1,1,n,l,r,x);}else if(opt==4||opt==5){int pos; scanf("%d",&pos);llong ans = sgt.query(1,1,n,pos,opt-3); printf("%lld\n",ans);}}return 0;
}

UOJ #164 [清华集训2015]V (线段树)相关推荐

  1. 【uoj#164】[清华集训2015]V 线段树维护历史最值

    题目描述 给你一个长度为 $n$ 的序列,支持五种操作: $1\ l\ r\ x$ :将 $[l,r]$ 内的数加上 $x$ : $2\ l\ r\ x$ :将 $[l,r]$ 内的数减去 $x$ , ...

  2. BZOJ 4732 UOJ #268 [清华集训2016]数据交互 (树链剖分、线段树)

    题目链接 (BZOJ) https://www.lydsy.com/JudgeOnline/problem.php?id=4732 (UOJ) http://uoj.ac/problem/268 题解 ...

  3. 【地狱副本】数据结构之线段树Ⅲ——区间最值/赋值/修改/历史值操作(HDU5306,Tyvj 1518,【清华集训2015】V,HDU6315,HDU1828,POJ3162)

    文章目录 Gorgeous Sequence Tyvj 1518 CPU监控 [清华集训2015]V Naive Operations Picture Walking Race Gorgeous Se ...

  4. UOJ #164 【清华集训2015】V (线段树)

    题目链接 http://uoj.ac/problem/164 题解 神仙线段树题. 首先赋值操作可以等价于减掉正无穷再加上\(x\). 假设某个位置从前到后的操作序列是: \(x_1,x_2,..., ...

  5. UOJ #268 BZOJ 4732 [清华集训2016]数据交互 (树链剖分、线段树)

    题目链接 (BZOJ) https://www.lydsy.com/JudgeOnline/problem.php?id=4732 (UOJ) http://uoj.ac/problem/268 题解 ...

  6. UOJ#7. 【NOI2014】购票 | 线段树 凸包优化DP

    题目链接 UOJ #7 题解 首先这一定是DP!可以写出: \[f[i] = \min_{ancestor\ j} \{f[j] + (d[j] - d[i]) * p[i] + q[i]\}\] 其 ...

  7. P3899 [湖南集训]谈笑风生(线段树合并)

    P3899 [湖南集训]谈笑风生 给定一颗以111号节点为根的树,如果a≠ba \neq ba​=b,且aaa是bbb的祖先,则aaa比bbb更厉害,如果a≠ba \neq ba​=b,且dis( ...

  8. CSU 2151 集训难度(线段树)

    其实是个超傻逼的题目,但是交了20几发,就死在一个写惯了的小错误上 这种题目一看建两个标记就好了, \(tag1\):表示区间加标记 \(tag2\):表示区间覆盖标记 那么下传方式很显然: 先下传 ...

  9. [联合集训6-25] 蓝雨 线段树+主席树+hash

    先考虑p=qp=qp=q的情况,习惯先把求第kkk大变成求第k" role="presentation" style="position: relative;& ...

最新文章

  1. 近些年有哪些口碑炸裂的项目管理工具?各具特色的项目管理工具我们该如何选择?
  2. android唤醒屏幕并解锁
  3. 关于python使用threadpool中的函数单个参数和多个参数用法举例
  4. 无障碍开发(一)之初认识
  5. Golang入门教程(十五)指针
  6. 解决 Ext.Ajax.request 同步请求实现问题 (Ext3.0)
  7. aws上负载均衡器标组端口_AWS CloudFormation:目标组没有关联的负载均衡器
  8. 如何在5分钟内通过身份验证构建RESTful API —全部从命令行(第1部分)
  9. linux命令怎么查看文件时间排序,linux中ls命令按照文件大小排...-ls命令按大小与时间排序文件...-ls按时间排序输出文件列表的实例分析_169IT.COM...
  10. python是什么软件-python一般用什么软件
  11. VSTS有Bug,分析数据库的维度和维度属性使用中文命名时候,作为报表参数会出错。虽然有解决办法但是头大。...
  12. (转)BCG出品史上最全Fintech-金融科技-发展趋势报告
  13. php连接mysql MariaDB_PHP+MariaDB数据库操作基本技巧
  14. 马老师的996,不是鸡汤,是​我的人生信条!
  15. 电商运营中京东运营法则
  16. 电信专家王煜全:手机监管面临三大困境
  17. switchport mode access
  18. 哪些人会看作业指导书?作业指导书怎样才能发挥作用?
  19. [RK3288][Android6.0] RK3288和RK3288-W版本说明
  20. VSTO:使用C#开发Excel、Word【10】

热门文章

  1. python 利用pyinstaller 编译.exe文件过程中编写完的.exe文件执行过程中闪退
  2. python pandas csv时间聚合_Python通过pandas操作excel常用功能
  3. 3DSlicer24:Module-Create Scripted
  4. WinForm之创建word并操作文档
  5. 漫谈C++ Builder多线程编程技术
  6. Delphi 中将对象作为参数传递的使用
  7. grub4dos初级教程-入门篇
  8. BUUCTF-WEB:[SUCTF 2019]EasySQL 1
  9. 从SOURCE_BUFFER单元开始存放了20个字母A, 编程将这20个字母A的字符串传送到DEST_BUFFER开始的单元中.
  10. 数组中删数(只删一个)