[CF935F]Fafa and Array
法法round(雾
题意:给一个序列$a_{1\cdots n}$,定义$\begin{align*}f=\sum\limits_{i=1}^{n-1}\left|a_i-a_{i+1}\right|\end{align*}$,修改是区间加,询问$(l,r,x)$表示把某个$a_i(i\in[l,r])$加上$x$后最大的$f$是多少
先考虑把某个$a_i$加上$x$后对$f$的影响,不失一般性,我们假设$a_{i-1}\leq a_{i+1}$,那么对$a_i$的大小分类讨论,有三种情况
①$a_i\leq a_{i-1},a_i\leq a_{i+1}$,我们不希望找到这样的位置,因为$f$有可能变小,实际上当$l\neq r$时$a_{l\cdots r}$不会全是这种情况(所有$a_i$都比它两边的元素小,矛盾),所以直接忽略即可(当$l=r$时还是要特殊处理的)
②$a_{i-1}\leq a_i\leq a_{i+1}$,$f$可能变大,变化量为$2(x+a_i-a_{i+1})$
③$a_i\geq a_{i+1},a_i\geq a_{i-1}$,$f$一定会变大,变化量为$2x$
所以我们先把原序列差分:$d_i=a_i-a_{i-1}$,然后在线段树的下标为$i$的位置存$\min(d_i,0)+\min(-d_{i+1},0)$,每次查询$[l,r]$的最大值$mx$,那么$\max(0,2(x+mx))$就是$f$的增量
取$\min$对应着③,如果没有③,我们找到的是最小的$|a_i-\max(a_{i-1},a_{i+1})|$,这使得$f$增量最大,最后还要和$0$取$\max$是因为$f$可能不变(即这个区间任何一个数加上$x$都不会变成③)
因为做了差分,所以区间修改就变成单点修改了,修改$d_l,d_{r+1}$和线段树中的$l-1,l,r,r+1$即可
#include<stdio.h>
typedef long long ll;
const ll inf=9223372036854775807ll;
ll max(ll a,ll b){return a>b?a:b;}
ll min(ll a,ll b){return a<b?a:b;}
ll abs(ll x){return x>0?x:-x;}
ll d[300010],mx[1200010];
int M;
ll num(int i){
return min(d[i],0)+min(-d[i+1],0);
}
void pushup(int x){mx[x]=max(mx[x<<1],mx[x<<1|1]);}
ll query(int s,int t){
ll res=-inf;
for(s+=M-1,t+=M+1;s^t^1;s>>=1,t>>=1){
if(~s&1)res=max(res,mx[s^1]);
if(t&1)res=max(res,mx[t^1]);
}
return res;
}
void modify(int x){
mx[x+M]=num(x);
for(x=(x+M)>>1;x;x>>=1)pushup(x);
}
int main(){
int n,m,i,op,l,r,x;
ll sum;
scanf("%d",&n);
for(M=1;M<n;M<<=1);
for(i=1;i<=n;i++)scanf("%I64d",d+i);
for(i=n;i>0;i--)d[i]-=d[i-1];
d[1]=0;
sum=0;
for(i=2;i<=n;i++)sum+=abs(d[i]);
for(i=M;i<M<<1;i++)mx[i]=-inf;
for(i=1;i<=n;i++)mx[i+M]=num(i);
for(i=M-1;i>0;i--)pushup(i);
scanf("%d",&m);
while(m--){
scanf("%d%d%d%d",&op,&l,&r,&x);
if(op==1){
if(l==r)
printf("%I64d\n",sum-abs(d[l])+abs(d[l]+x)-abs(d[l+1])+abs(d[l+1]-x));
else
printf("%I64d\n",sum+max(0,2*(x+query(l,r))));
}else{
if(l>1)sum-=abs(d[l]);
d[l]+=x;
if(l>1)sum+=abs(d[l]);
modify(l);
if(l>1)modify(l-1);
if(r<n){
sum-=abs(d[r+1]);
d[r+1]-=x;
sum+=abs(d[r+1]);
modify(r+1);
modify(r);
}
}
}
}
[CF935F]Fafa and Array的更多相关文章
- javascript中的Array对象 —— 数组的合并、转换、迭代、排序、堆栈
Array 是javascript中经常用到的数据类型.javascript 的数组其他语言中数组的最大的区别是其每个数组项都可以保存任何类型的数据.本文主要讨论javascript中数组的声明.转换 ...
- ES5对Array增强的9个API
为了更方便的对Array进行操作,ES5规范在Array的原型上新增了9个方法,分别是forEach.filter.map.reduce.reduceRight.some.every.indexOf ...
- JavaScript Array对象
介绍Js的Array 数组对象. 目录 1. 介绍:介绍 Array 数组对象的说明.定义方式以及属性. 2. 实例方法:介绍 Array 对象的实例方法:concat.every.filter.fo ...
- 了解PHP中的Array数组和foreach
1. 了解数组 PHP 中的数组实际上是一个有序映射.映射是一种把 values 关联到 keys 的类型.详细的解释可参见:PHP.net中的Array数组 . 2.例子:一般的数组 这里,我 ...
- 关于面试题 Array.indexof() 方法的实现及思考
这是我在面试大公司时碰到的一个笔试题,当时自己云里雾里的胡写了一番,回头也曾思考过,最终没实现也就不了了之了. 昨天看到有网友说面试中也碰到过这个问题,我就重新思考了这个问题的实现方法. 对于想进大公 ...
- javascript之活灵活现的Array
前言 就如同标题一样,这篇文章将会灵活的运行Array对象的一些方法来实现看上去较复杂的应用. 大家都知道Array实例有这四个方法:push.pop.shift.unshift.大家也都知道 pus ...
- 5.2 Array类型的方法汇总
所有对象都具有toString(),toLocaleString(),valueOf()方法. 1.数组转化为字符串 toString(),toLocaleString() ,数组调用这些方法,则返回 ...
- OpenGL ES: Array Texture初体验
[TOC] Array Texture这个东西的意思是,一个纹理对象,可以存储不止一张图片信息,就是说是是一个数组,每个元素都是一张图片.这样免了频繁地去切换当前需要bind的纹理,而且可以节省系统资 ...
- Merge Sorted Array
Given two sorted integer arrays nums1 and nums2, merge nums2 into nums1 as one sorted array. Note:Yo ...
随机推荐
- java一个接口可以继承另外一个接口吗
一个接口可以继承多个接口. interface C extends A, B {}是可以的. 一个类可以实现多个接口: class D implements A,B,C{} 但是一个类只能继承一个类, ...
- 这次OpenSSL HeartBleed漏洞是怎么一回事呢?
“心脏出血”(Heartbleed)被称为互联网史上最严重的安全漏洞之一,波及了大量常用网站.服务,包括很多人每天都在用的 Gmail 等等,可能导致用户的密码.信用卡轻易泄露.但是我们可能对它还不是 ...
- linux 条件判断式
1.利用if ...then if [ 判断条件 ];then 指令 fi 实例一 Y/N: #!/bin/bash #Program: # This program shows "Hell ...
- Hyperledger Fabric架构详解
区块链开源实现HYPERLEDGER FABRIC架构详解 区块链开源实现HYPERLEDGER FABRIC架构详解 2018年5月26日 陶辉 Comments 10 Comments hyper ...
- tyvj1305 最大子序和(单调队列
题目地址:http://www.joyoi.cn/problem/tyvj-1305 最大子序和 题目限制 时间限制 内存限制 评测方式 题目来源 1000ms 131072KiB 标准比较器 Loc ...
- HDU 多校对抗第三场 L Visual Cube
Problem L. Visual Cube Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 524288/524288 K (Java ...
- supervisor提高nodejs调试效率
1.NodeJS环境安装 2.安装supervisor npm install supervisor -g (表示安装到全局路径下) 开发nodejs程序,调试的时候,无论你修改了代码的哪一部分,都 ...
- PHP文件操作函数一
<?php/*Created on 2013-6-26*///判断文件的类型echo filetype("array.php")."<br />&quo ...
- bzoj2811 [Apio2012]Guard
传送门:http://www.lydsy.com/JudgeOnline/problem.php?id=2811 [题解] 首先我们先把没看到忍者的段去掉,可以用线段树做. 如果剩下的就是K,那么特判 ...
- face++ API接口调用
人脸识别 首先我想描述一下,在学校的时候一直好奇人脸识别与人脸检测这个技术,之后做了很多实验,曾经使用过很多简单的算法来做人脸相似度对比,比如:夹角余弦算法.判断两个矩阵之间对应位置元素相同来做统计. ...