牛客ACM赛 C 区区区间间间
链接 C 区区区间间间
- 给定长度为\(n\)序列,求$$\sum_{i=1}^{n} \sum_{j=i}^{n} max-min$$
- 其中\(max\),\(min\)为区间最大,最小值,\(n\leq 10^5\)。
- \(cdq\)分治模板题,每次考虑跨过\(mid\)的区间。
- 如果考虑从\(mid\)到\(le\)枚举左端点,那么区间之间的最大最小值是单调的。
- 在右边维护\(j,k\),表示当前最大、最小值能管辖到的最大范围。
- 那么贡献就是\(mid\)到\(j,k\)的长度和当前\(mn,mx\)的乘积,以及后面所有最大最小值的总和。
- 对\(mid\)到\(r\)前缀和优化即可。
#include<bits/stdc++.h>
#define R register int
#define ll long long
using namespace std;
const int N=100001;
ll n,t,w[N],Sm[N],Sx[N];ll ans;
int gi(){
R x=0,k=1;char c=getchar();
while((c<'0'||c>'9')&&c!='-')c=getchar();
if(c=='-')k=-1,c=getchar();
while(c>='0'&&c<='9')x=(x<<3)+(x<<1)+c-'0',c=getchar();
return x*k;
}
void CDQ(R le,R ri){
if(le==ri)return;
R mid=(le+ri)>>1;CDQ(le,mid),CDQ(mid+1,ri);
Sm[mid]=Sx[mid]=0;
for(ll i=mid+1,mx=0,mn=1e9;i<=ri;++i){
mx=max(mx,w[i]),mn=min(mn,w[i]);
Sm[i]=Sm[i-1]+mn,Sx[i]=Sx[i-1]+mx;
}
for(ll i=mid,j=mid,k=mid,mx=0,mn=1e9;i>=le;--i){
mx=max(mx,w[i]),mn=min(mn,w[i]);
for(;j<ri&&w[j]>=mn&&w[j+1]>=mn;++j);
for(;k<ri&&w[k]<=mx&&w[k+1]<=mx;++k);
ans-=1ll*mn*(j-mid)+(Sm[ri]-Sm[j]);
ans+=1ll*mx*(k-mid)+(Sx[ri]-Sx[k]);
}
}
void sol(){
n=gi(),ans=0;
for(R i=1;i<=n;++i)w[i]=gi();
CDQ(1,n),printf("%lld\n",ans);
}
int main(){
t=gi();
while(t--)sol();
return 0;
}
牛客ACM赛 C 区区区间间间的更多相关文章
- NowCoder--牛可乐发红包脱单ACM赛C_区区区间间间
题目链接:C_区区区间间间 思路:算贡献,求出每个数为当前最大值时所在的区间个数,和每个数为最小值的区间个数 和这个题有点类似 搭配食用效果更佳 点击这里 #include<bits/stdc+ ...
- 牛客训练赛25-A-最长区间
https://www.nowcoder.com/acm/contest/158#question 这题问最长的严格连续递增序列的最长长度是多少? 最开始感觉这道题不可做,因为有1e5个点,还有1e5 ...
- 牛客ACM赛 B [小a的旅行计划 ]
链接 B 小a的旅行计划 把\(n\)个数中选任意数分成\(a,b\)两个集合,集合无区别,要求不包含且有交,求方案数.\(n\leq 10^{13}\) 首先讨论\(a,b\)并集是否为全集: 若是 ...
- 牛客网 牛客小白月赛5 I.区间 (interval)-线段树 or 差分数组?
牛客小白月赛5 I.区间 (interval) 休闲的时候写的,但是写的心情有点挫,都是完全版线段树,我的一个队友直接就水过去了,为啥我的就超内存呢??? 试了一晚上,找出来了,多初始化了add标记数 ...
- 牛客网小白月赛5I区间(差分数组)
链接:https://www.nowcoder.com/acm/contest/135/I来源:牛客网 时间限制:C/C++ 2秒,其他语言4秒 空间限制:C/C++ 32768K,其他语言65536 ...
- 牛客小白月赛5 I - 区间
看到一份不错的操作..... 链接:https://www.nowcoder.com/acm/contest/135/I 来源:牛客网 Apojacsleam喜欢数组. 他现在有一个n个元素的数组a, ...
- 牛客小白赛5 无关(relationship) 容斥原理(计算因子数的模板)
链接:https://www.nowcoder.com/acm/contest/135/A来源:牛客网 若一个集合A内所有的元素都不是正整数N的因数,则称N与集合A无关. 给出一个含有k个元素的集 ...
- 牛客巅峰赛S2第6场题解
牛客编程巅峰赛S2第6场 A-StringⅡ 题目 题目描述 给出一个仅包含小写字母的字符串s,你最多可以操作k次,使得任意一个小写字母变为与其相邻的小写字母(ASCII码差值的绝对值为1),请你求出 ...
- 牛客小白赛1 F题三视图
链接:https://www.nowcoder.com/acm/contest/85/F来源:牛客网 题目描述 Etéreo 拿出家里的许多的立方体积木,堆成了一个三维空间中的模型.既然你高考选了技术 ...
随机推荐
- InfluxDB安装使用
influxdb简介 启动步骤 服务启停:sudo service influxdb start/stop/restart 安装过程: 1.增加yum源 cat <<EOF | sud ...
- Linux shell - 修改文件所属用户和组 (chown, chgrp)
在工作中,会遇到这样的情况,需要把目录所属的的root用户更改到普通用户,root组更改到普通组. sha-q:/ # ll drwxr-xr-x 2 root root 4096 2014-09-1 ...
- win7下面安装flex和bison
通过Cygwin工具进行安装 下载地址cygwin 安装截图: 搜索flex,选择相应的版本进行安装 搜索bison 然后下一步 安装完成后,将D:\cygwin64\bin路径添加到PATH环境变量 ...
- unity项目中使用BUGLY遇到的的几个问题
1,第一次对外测试中,发现某些机型游戏中卡死了,但bugly上没报错.后来发现是我们的代码使用 try catch把异常捕获了但什么都没做. 2,别人家项目的bugly上报都能显示出文件和代码行,我们 ...
- (转)IDataGridViewEditingControl 接口 作用
本文转载自:http://blog.csdn.net/zx13525079024/article/details/4814575 IDataGridViewEditingControl 接口 定义承载 ...
- 打印流PrintWriter
* 打印流 * 字节流打印流 PrintStream * 字符流打印流PrintWriter * * 打印流的特点: * A:只有写数据的,没有读取数据,只能操作目的地,不能操作数据源 * * B:可 ...
- WordPress致命错误 紧急处理代码
将下面代码添加到当前主题函数模板 functions.php 中: dadd_filter( 'wp_fatal_error_handler_enabled', '__return_false' );
- python 数据结构考题
1. 以下关于python数据结构说法正确的是 python中list可以动态的更新, 但是不容许嵌套 python中tuple可以动态更新, 但是不容许嵌套 python中dict保存键值对, 并且 ...
- Web前端开发 --》 如何实现页面同时在移动端和pc端的兼容问题
很简单,只需要在html文件中对你引入的css进行一个类似于媒体查询的操作 <!DOCTYPE html> <html lang="en"> <hea ...
- python+selenium链接对象操作
对于链接对象常见的操作有:单击.获取链接文字.获取链接地址等: from selenium import webdriverfrom time import sleep driver = webdri ...