牛客练习赛 小A与最大子段和 解题报告
小A与最大子段和
题意
在一个序列 \(\{a\}\) 里找到一个非空子段 \(\{b\}\), 满足 \(\sum\limits_{i=1}^{|b|}b_i\times i\) 最大
\(n\le 200000,|a_i|\le 2000\)
长的都一脸的斜率优化
考虑表示一个子段\([l+1,r]\)为
&\sum_{i=l+1}^ra_i(i-l)\\
&=\sum_{i=l+1}^ra_i\times i-a_i\times l
\end{aligned}
\]
设\(A_k=\sum_{i=1}^k a_ii,B_k=\sum_{i=1}^k a_i\)
那继续化简为
\]
然后我们枚举\(r\),想办法搞一下\(l\)
维护一个\((i,B_i\times i-A_i)\)的上凸包,然后发现是对斜率询问最大截距,直接在凸包上三分就可以了。
Code:
#include <cstdio>
#include <algorithm>
#define ll long long
const int N=2e5+10;
using std::max;
int n,tot;
ll A[N],B[N];
struct Point
{
	ll x,y;
	Point(){}
	Point(ll X,ll Y){x=X,y=Y;}
	Point friend operator -(Point a,Point b){return Point(a.x-b.x,a.y-b.y);}
	ll cal(ll d){return d*x+y;}
}s[N];
ll Cross(Point a,Point b){return a.x*b.y-a.y*b.x;}
void ins(Point a)
{
	while(tot>1&&Cross(a-s[tot],s[tot]-s[tot-1])<=0) --tot;
	s[++tot]=a;
}
int main()
{
	scanf("%d",&n);
	ins(Point(0,0));
	ll ans=-(1ll<<50),a;
	for(int i=1;i<=n;i++)
 	{
 		scanf("%lld",&a);
 		A[i]=A[i-1]+a*i;
 		B[i]=B[i-1]+a;
 		int l=1,r=tot;
 		while(l<r)
 		{
 			int mid=l+r>>1;
 			if(s[mid].cal(-B[i])<s[mid+1].cal(-B[i])) l=mid+1;
 			else r=mid;
 		}
 		ans=max(ans,A[i]+s[l].cal(-B[i]));
 	    ins(Point(i,B[i]*i-A[i]));
 	}
 	printf("%lld\n",ans);
	return 0;
}
2019.2.16
牛客练习赛 小A与最大子段和 解题报告的更多相关文章
- 牛客练习赛 小D的剑阵 解题报告
		小D的剑阵 题意链接: https://ac.nowcoder.com/acm/contest/369/F 来源:牛客网 现在你有 \(n\) 把灵剑,其中选择第i把灵剑会得到的 \(w_i\) 攻击 ... 
- 牛客练习赛 小A与任务 解题报告
		小A与任务 链接: https://ac.nowcoder.com/acm/contest/369/B 来源:牛客网 题目描述 小A手头有 \(n\) 份任务,他可以以任意顺序完成这些任务,只有完成当 ... 
- 牛客练习赛 小D的Lemon 解题报告
		小D的Lemon 题意 已知 \[ g(x)=\left\{\begin{matrix} 1&,x=1\\ \sum_{i=1}^qk_i&,otherwise \end{matrix ... 
- 牛客 545A 小A与最大子段和 & CF 660F Bear and Bowling 4
		大意: 给定序列$a$, 求选择一个子区间$[l,r]$, 使得$\sum\limits_{i=l}^r(i-l+1)a_i$最大. $n\le2e5, |a_i|\le 1e7$. 记$s[i]=\ ... 
- nowcoder(牛客网)提高组模拟赛第一场 解题报告
		T1 中位数(二分) 这个题是一个二分(听说是上周atcoder beginner contest的D题???) 我们可以开一个数组b存a,sort然后二分b进行check(从后往前直接遍历check ... 
- nowcoder(牛客网)普及组模拟赛第一场 解题报告
		蒟蒻我可能考了一场假试 T1 绩点 这题没什么好说的,应该是只要会语言的就会做. T2 巨大的棋盘 一个模拟题吧qwq,但是要注意取模的时候先加上n或者m再取模,要不然会错的. #include< ... 
- 牛客练习赛48 C  小w的糖果 (数学,多项式,差分)
		牛客练习赛48 C 小w的糖果 (数学,多项式) 链接:https://ac.nowcoder.com/acm/contest/923/C来源:牛客网 题目描述 小w和他的两位队友teito.toki ... 
- 牛客练习赛48 A· 小w的a+b问题  (贪心,构造,二进制)
		牛客练习赛48 A· 小w的a+b问题 链接:https://ac.nowcoder.com/acm/contest/923/A来源:牛客网 时间限制:C/C++ 1秒,其他语言2秒 空间限制:C/C ... 
- 牛客练习赛44  A	小y的序列 (模拟,细节)
		链接:https://ac.nowcoder.com/acm/contest/634/A 来源:牛客网 小y的序列 时间限制:C/C++ 1秒,其他语言2秒 空间限制:C/C++ 32768K,其他语 ... 
随机推荐
- Linux性能评测工具之一:gprof篇
			这些天自己试着对项目作一些压力测试和性能优化,也对用过的测试工具作一些总结,并把相关的资料作一个汇总,以便以后信手拈来! 1 简介 改进应用程序的性能是一项非常耗时耗力的工作,但是究竟程序中是哪些函数 ... 
- Scala学习(八)---Scala继承
			Scala继承 摘要: 在本篇中,你将了解到Scala的继承与Java和C++最显著的不同.要点包括: 1. extends.final关键字和Java中相同 2. 重写方法时必须用override ... 
- 一致性哈希(hash)算法
			一.算法背景 一致性哈希算法在1997年由麻省理工学院的Karger等人在解决分布式Cache中提出的,设计目标是为了解决因特网中的热点(Hot spot)问题,初衷和CARP十分类似.一致性哈希修正 ... 
- ML.NET 示例:开篇
			写在前面 准备近期将微软的machinelearning-samples翻译成中文,水平有限,如有错漏,请大家多多指正. 如果有朋友对此感兴趣,可以加入我:https://github.com/fei ... 
- bootstrap datetimepicker 格式化yyyymmdd时,无法读取yyyymmdd格式
			不知为何,java程序员爱用yyyymmdd格式化日期?导致bootstrap datetimepicker无法解析正确的日期 发现js中yyyymmdd不是正常能够解析的日期 查看datetimep ... 
- LeetCode Pow(x, n) (快速幂)
			题意 Implement pow(x, n). 求X的N次方. 解法 用正常的办法来做是会超时的,因为可能有21亿次方的情况,所以需要优化一下.这里用到了快速幂算法,简单来说就是将指数分解成二进制的形 ... 
- Java 基础之一对象导论
			对象导论 1.1 抽象过程 所有编程语言都提供抽象机制.人们所能解决的问题的复杂性直接取决于抽象的类型和质量. 汇编语言是对底层机器的轻微抽象. 我们将问题空间中的元素及其再解空间中的表示称为对象.这 ... 
- 《坦克世界》1.0+:使用 CPU 优化的图形和物理丰富用户体验
			本文以<坦克世界>为例,介绍 Wargaming 使用 CPU 多核和 CPU 单指令多数据 (SIMD) 功能显著提升游戏沉浸式体验的创新方法.我们以英特尔® 线程构建模块(英特尔® T ... 
- 分布式监控系统Zabbix3.4-针对MongoDB性能监控操作笔记
			公司在IDC机房的一台服务器上部署了MongoDB,由于所存储的业务数据比较重要,所以对MongoDB的监控显得尤为重要!Zabbix监控MongoDB性能的原理:通过echo "db.se ... 
- 第三次作业(1)  Visual Studio程序安装过程和练习过程
			Visual Studio程序安装过程和练习过程 第一步 首先要在网上找一个VS2013的安装包,之后我安装在D盘上,C盘上也需要有5.2G空间,勾选相应的选项,才能继续安装. 安装的过程很漫长,接近 ... 
