题目链接

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. 【题解】P4247 [清华集训]序列操作(线段树修改DP)

    [题解]P4247 [清华集训]序列操作(线段树修改DP) 一道神仙数据结构(DP)题. 题目大意 给定你一个序列,会区间加和区间变相反数,要你支持查询一段区间内任意选择\(c\)个数乘起来的和.对1 ...

  3. 清华集训2015 V

    #164. [清华集训2015]V http://uoj.ac/problem/164 统计 描述 提交 自定义测试 Picks博士观察完金星凌日后,设计了一个复杂的电阻器.为了简化题目,题目中的常数 ...

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

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

  5. 「清华集训2015」V

    「清华集训2015」V 题目大意: 你有一个序列,你需要支持区间加一个数并对 \(0\) 取 \(\max\),区间赋值,查询单点的值以及单点历史最大值. 解题思路: 观察发现,每一种修改操作都可以用 ...

  6. [UOJ#274][清华集训2016]温暖会指引我们前行

    [UOJ#274][清华集训2016]温暖会指引我们前行 试题描述 寒冬又一次肆虐了北国大地 无情的北风穿透了人们御寒的衣物 可怜虫们在冬夜中发出无助的哀嚎 “冻死宝宝了!” 这时 远处的天边出现了一 ...

  7. 2018.07.28 uoj#164. 【清华集训2015】V(线段树)

    传送门 线段树好题. 要求支持的操作: 1.区间变成max(xi−a,0)" role="presentation" style="position: rela ...

  8. UOJ #164. 【清华集训2015】V | 线段树

    题目链接 UOJ #164 题解 首先,这道题有三种询问:区间加.区间减(减完对\(0\)取\(\max\)).区间修改. 可以用一种标记来表示--标记\((a, b)\)表示把原来的值加上\(a\) ...

  9. @uoj - 164@ 【清华集训2015】V

    目录 @description@ @solution@ @accepted code@ @details@ @description@ Picks博士观察完金星凌日后,设计了一个复杂的电阻器.为了简化 ...

随机推荐

  1. (八)装配Bean(2)

    二.在Java类中进行显式的装配 显式配置有两种: 1. 一种是在java(本文讲解)   2. 另一种是xml配置文件(第一章有讲) 案例一: 使用java显式装配+@autowired自动装配的方 ...

  2. Spring Boot 全局Exception处理

    一.代码如下 package com.zxguan; import org.springframework.web.bind.annotation.ControllerAdvice; import o ...

  3. Java ShellSort

    Java ShellSort /** * <html> * <body> * <P> Copyright 1994-2018 JasonInternational ...

  4. C# 第一次做项目。一些经验总结。

    这是我的第一篇博客,写得不好望大家多多包涵. 初学C#2个多月,拿着老师给的项目,试着做了做,发现自己在编程方面有很多陋习与编程知识方面的不足. 首先是没有遵守某一个设计模式,这导致我想到哪里就做到了 ...

  5. Asp.Net Core 轻松学系列-3项目目录和文件作用介绍

    目录 前言 结语 前言     上一章介绍了 Asp.Net Core 的前世今生,并创建了一个控制台项目编译并运行成功,本章的内容介绍 .NETCore 的各种常用命令.Asp.Net Core M ...

  6. JS中的原型对象与构造器

    在Javascript中:原型对象是属于构造函数的,不属于实例:实例只能共享原型对象中的属性和方法(当然也可以有自己的属性和方法,或者覆盖原型中同名的属性和方法):构造器constructor属于原型 ...

  7. 三、eureka服务端获取服务列表

    所有文章 https://www.cnblogs.com/lay2017/p/11908715.html 正文 eureka服务端维护了一个服务信息的列表,服务端节点之间相互复制服务信息.而作为eur ...

  8. 记录在苹果X手机上运行遇到的代码Dom被阻塞不更新的一个坑

    一.问题产生背景: 开发支付功能,代码逻辑如下:点击支付后,请求后台接口得到流水号以及第三方支付台链接,跳转支付台(在苹果手机则是弹出支付台层):支付完毕后返回支付页面,或中途退出支付台返回支付页面: ...

  9. K2 BPM_“选BPM还是RPA?”,这不是一道单选题_全业务流程管理专家

    在我们和企业讨论流程自动化的时候,经常会被问到一个问题,“公司目前正在调研市面上的业务流程自动化产品,我们已经把选择范围缩小到了BPM和RPA之间.我们应该怎么选择?BPM能做的好像RPA都能做到.” ...

  10. Cryptography -- 密码学

    Introduction to Cryptography Cryptography enables you to store sensitive information or transmit it ...