[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 ...
随机推荐
- HDU1213:How Many Tables(并查集)
How Many Tables Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)T ...
- ext4文件系统由文件的inode号定位其inode Table
在ubuntu中(以16.06为例),stat filename 可以查看文件的inode数值,但是如何确定该inode项具体在哪个块组下的inode Table中不是那么容易,接下来通过一步步计算来 ...
- linux查看操作系统是多少位
有三种方法: 1.echo $HOSTTYPE 2.getconf LONG_BIT,此处不应该是getconf WORD_BIT命令,在64位系统中显示的是32 3.uname -a 出现" ...
- 请把<ul><li>第1行</li><li>第2行</li>...</ul>(ul之间有10个li元素)插入body里面,注意:需要考虑到性能问题。
var html = [],i;for(i = 0; i < 10; i++){ html.push('<ul><li>第' + (i+1) + '行</li> ...
- 设置查看java的源程序
1.点 “window”-> "Preferences" -> "Java" -> "Installed JRES" 2. ...
- org.springframework.web.HttpRequestMethodNotSupportedException: Request method 'GET' not supported解决!
org.springframework.web.HttpRequestMethodNotSupportedException: Request method 'GET' not supported解决 ...
- Spring - IoC(10): 生命周期
Spring 容器可以管理 singleton 作用域 Bean 的生命周期,容器能够跟踪 Bean 实例的创建.销毁.管理 Bean 生命周期行为主要有两个时机: 注入 Bean 的依赖关系之后 即 ...
- js错误处理
导致程序无法继续执行的异常状态称为错误. js中一旦发生错误,就会自动创建一个Error类型对象 js中有6中错误类型: SyntaxError 语法错误 ReferenceError 引用错误,找不 ...
- 【bzoj1096-仓库建设】斜率优化
dsy1096: [ZJOI2007]仓库建设 [问题描述] L公司有N个工厂,由高到底分布在一座山上.如图所示,工厂1在山顶,工厂N在山脚. 由于这座山处于高原内陆地区(干燥少雨),L公司一般把产品 ...
- laravel 获得各个根文件夹路径的方法及路由的一些使用
各个根文件夹路径的方法 APP目录: app_path(); config目录: config_path(); public目录: public_path(); storage目录: storage_ ...