Function题解
这个题最优策略一定是向左上走到某一列再往上一直走。
n*q在线暴力可做,离线按y排序,单调栈维护凸壳。
具体来说:对于i<j若A[i]>A[j] 即j的斜率小而且纵截距小,一定比i优,并且易得栈里直线的交点一定是递增的。
然后直接在交点二分即可。
#include<cstdio>
#include<algorithm>
#define N 500005
#define int long long
using namespace std;
int s[N],top,a[N],b[N],tot,sum[N],n;
double jk[N];
double Get(int i,int j){return 1.0*(b[i]-b[j])/(a[j]-a[i]);}
inline int read()
{
int x=,f=;char c=getchar();
while(c>''||c<''){if(c=='-')f=-;c=getchar();}
while(c>=''&&c<='')x=x*+c-,c=getchar();
return x*f;
}
struct query{
int x,y,id;
inline void init(){x=read(),y=read();}
inline friend bool operator < (const query a,const query b){return a.y<b.y;}
}Q[N];
int ans[N];
inline void update(int pos)
{
while(top&&a[s[top]]>=a[pos])top--;
while(top>&&Get(s[top],s[top-])<Get(pos,s[top]))top--;
s[++top]=pos;
if(top>)jk[n-top]=Get(s[top],s[top-]);
return ;
}
signed main()
{
n=read();
for(int i=;i<=n;i++) a[i]=read(),sum[i]=sum[i-]+a[i],b[i]=i*a[i]-sum[i];
int q=read(),j=;
for(int i=;i<=q;i++) Q[i].init(),Q[i].id=i;
sort(Q+,Q+q+);
for(int i=;i<=q;i++)
{
while(j<=Q[i].y)update(j),++j;
int now=lower_bound(jk+n-top,jk+n-,Q[i].x-Q[i].y)-jk;now=n-now;
ans[Q[i].id]=a[s[now]]*(Q[i].x-Q[i].y)+b[s[now]]+sum[Q[i].y];
}
for(int i=;i<=q;i++)printf("%lld\n",ans[i]);
return ;
}
Function题解的更多相关文章
- CF221A Little Elephant and Function 题解
		
Content 小象有一个序列 \(a_1,a_2,a_3,...,a_n\) (其中 \(a_i=i\))和一个递归函数 \(f(x)\).\(f(x)\) 的操作如下: 初始时,\(x=n\). ...
 - LuoguP7127 「RdOI R1」一次函数(function) 题解
		
Content 设 \(S_k\) 为直线 \(f(x)=kx+k-1\),直线 \(f(x)=(k+1)x+k\) 与 \(x\) 轴围成的三角形的面积.现在给出 \(t\) 组询问,每组询问给定一 ...
 - Leetcode-237 Delete Node in a Linked List
		
#237. Delete Node in a Linked List Write a function to delete a node (except the tail) in a singl ...
 - LeetCode Basic Calculator II
		
原题链接在这里:https://leetcode.com/problems/basic-calculator-ii/ Implement a basic calculator to evaluate ...
 - codeforcess水题100道
		
之所以在codeforces上找这100道水题的原因是为了巩固我对最近学的编程语言的掌握程度. 找的方式在codeforces上的PROBLEMSET中过的题最多的那些题里面出现的最前面的10个题型, ...
 - 通过百度echarts实现数据图表展示功能
		
现在我们在工作中,在开发中都会或多或少的用到图表统计数据显示给用户.通过图表可以很直观的,直接的将数据呈现出来.这里我就介绍说一下利用百度开源的echarts图表技术实现的具体功能. 1.对于不太理解 ...
 - HDU 6156 Palindrome Function(数位DP)题解
		
思路: 数位dp的操作是dfs+记忆化,我们dp开四维:位置,长度,进制,是否回文.然后每次暴搜记录下每个位置的数字是什么,搜到对称轴另一边需要检查是否符合回文. 终于把友谊赛的题目都补完了...没做 ...
 - HDU 5608 function(莫比乌斯反演 + 杜教筛)题解
		
题意: 已知\(N^2-3N+2=\sum_{d|N}f(d)\),求\(\sum_{i=1}^nf(i) \mod 1e9+7\),\(n\leq1e9\) 思路: 杜教筛基础题? 很显然这里已经设 ...
 - CF1036A Function Height 题解
		
Content 给定一个坐标系,在它的 \(x\) 轴上有 \(2n+1\) 个点 \(P_0,P_1,P_2,...,P_{2n}\),其中对于 \(0\leqslant i\leqslant 2n ...
 
随机推荐
- openpyxl中遇到TypeError: 'generator' object is not subscriptable的问题和解决方案
			
今天在搭建驱动数据框架用到了一个叫 openpyxl的包用来解析excel数据 随后就出现了TypeError: 'generator' object is not subscriptable的bug ...
 - jsp隐含对象(内置对象)
			
JSP共有以下9个内置的对象: request HttpServletRequest类的实例,用户端请求,此请求会包含来自GET/POST请求的参数 response HttpServletRespo ...
 - mac系统Intellij Idea的java环境配置:JDK + Tomcat + Maven
			
一.JAVA JDK查看与配置 1.查看java路径详细信息: /usr/libexec/java_home -V 2.java默认路径 jdk1.6: /System/Library/Java/Ja ...
 - asp.net开源流程引擎API开发调用接口大全-工作流引擎设计
			
关键词: 工作流引擎 BPM系统 接口调用 工作流快速开发平台 工作流流设计 业务流程管理 asp.net 开源工作流 一.程序调用开发接口二. 接口说明 所谓的驰骋工作流引擎的接口,在B ...
 - canvas实现平面迁徙图
			
前言 最近在做自己维护的一个可视化工具的时候,在添加基于echart的雷达图的时候,按照echart官网案例写完发现在自己项目中无法正常运行,排查了一番发现是我项目中echart的版本太低.找到问题原 ...
 - 复杂模型可解释性方法——LIME
			
一.模型可解释性 近年来,机器学习(深度学习)取得了一系列骄人战绩,但是其模型的深度和复杂度远远超出了人类理解的范畴,或者称之为黑盒(机器是否同样不能理解?),当一个机器学习模型泛化性能很好时 ...
 - VUE--插值的操作
			
一.vue常见的指令 v-once:保留第一次渲染结果 v-html :把html代码解析,只显示内容 v-pre :原样输出 v-cloak :解决文本闪烁问题 v-text :显示文本 二.v-b ...
 - eclipse常用快捷键即项目操作
			
快捷键: 1.代码提示:Alt+/ 2.撤销上一步操作:Ctrl+z:取消撤销:Ctrl+y: 3.如何注销一整段代码?☞▲第一种注释方法是每行代码前加//:先选中,然后按Ctrl+/:取消注销方法一 ...
 - 基于powershell的socks代理
			
0x01 前言 在实战中,内网的代理尤其重要,而常见的端口转发被反病毒软件已经盯死,那么学习使用基于powershell的渗透脚本进行代理.端口转发的非常有必要的. 0x02 使用 介绍ithub: ...
 - Mongodb 常见的查询语句及与 mysql 对比
			
db.users.find()select * from users db.users.find({"age" : 27})select * from users where ag ...