P7294-[USACO21JAN]Minimum Cost Paths P【单调栈】
正题
题目链接:https://www.luogu.com.cn/problem/P7294
题目大意
\(n\times m\)的网格,当你在\((x,y)\)时你有两种选择
- 花费\(x^2\)的代价向右移动
- 花费\(c_y\)的代价向下移动
\(q\)次询问\((1,1)\)走到\((x,y)\)的最小代价。
\(1\leq n\leq 10^9,1\leq m,q\leq 2\times 10^5\)
解题思路
假设我们开始都是直接走最上面向右的路(也就是代价都是\(1^2\))。
然后考虑在某个位置\((x,y)\)要走到\((n,m)\)时向下走会产生的贡献为\(c_y+(m-y)\times (2x+1)\)(后面要抬\(m-y\)个横着走,然后从\(x^2\)到\((x+1)^2\)要到加\(2x+1\))。
然后拆一下就是\(c_y+m-y+2xm-2xy\)。发现斜率\(-2y\)是按照\(y\)递增递减的,而且我们要求选出的若干个\(c_y\)的\(y\)一定要递增,但是这样的话我们选出来的一定是递增的所以我们只需要考虑对于每个\(x\)选择一个\(y\)使得最小化\(c_y+(m-y)\times (2x+1)\)。
按照询问排序,一个一个加入新的\(c_y\),按照斜率维护一个上凸壳,然后在凸壳上面二分就好了。
时间复杂度\(O(m+q\log m)\)
code
#include<cstdio>
#include<cstring>
#include<algorithm>
#define ll long long
using namespace std;
const ll N=2e5+10;
struct node{
ll n,m,id;
}q[N];
ll n,m,t,top,b[N],k[N],s[N],sum[N],l[N],r[N],ans[N];
ll calc(ll i,ll j)//i<j
{return (b[j]-b[i]+k[i]-k[j]-1)/(k[i]-k[j]);}
ll cap(ll i,ll j){
ll x=calc(i,j);
if(x<=l[i])return 1;
return 0;
}
ll getf(ll x,ll l,ll r)
{return (r+l)*(r-l+1)/2*k[x]+b[x]*(r-l+1);}
bool cmp(node x,node y)
{return x.m<y.m;}
signed main()
{
// freopen("data.in","r",stdin);
// freopen("data.out","w",stdout);
scanf("%lld%lld",&n,&m);
for(ll i=1;i<=m;i++){
scanf("%lld",&b[i]);
b[i]=b[i]-i;k[i]=2*(-i);
}
scanf("%lld",&t);
for(ll i=1;i<=t;i++){
scanf("%lld%lld",&q[i].n,&q[i].m);
q[i].id=i;
}
sort(q+1,q+1+t,cmp);
for(ll i=1,z=1;i<=m;i++){
r[i]=n;
while(top>0&&cap(s[top],i))top--;
if(top)l[i]=max(calc(s[top],i),1ll);else l[i]=1;
if(l[i]<=r[i]){
r[s[top]]=l[i]-1;s[++top]=i;
sum[top-1]=((top>1)?sum[top-2]:0)+getf(s[top-1],l[s[top-1]],r[s[top-1]]);
sum[top]=sum[top-1]+getf(i,l[i],r[i]);
}
while(z<=t&&q[z].m<=i){
ll qn=q[z].n-1,L=1,R=top;
while(L<=R){
ll mid=(L+R)>>1;
if(r[s[mid]]<qn)L=mid+1;
else R=mid-1;
}
ans[q[z].id]=sum[L-1]+getf(s[L],l[s[L]],qn)+(qn+1)*qn*i+i*qn+i-1;
z++;
}
}
for(ll i=1;i<=t;i++)
printf("%lld\n",ans[i]);
return 0;
}
P7294-[USACO21JAN]Minimum Cost Paths P【单调栈】的更多相关文章
- [Agc005D/At2060] Minimum Sum - 单调栈
鉴于早上那题让我怀疑单调栈白学,特意来复习下单调栈 题意 考虑按照每个元素对答案的贡献来统计,那么我们只需要找到每个元素左边右边第一个比它小的就可 这题给的又是排列,简直不能再良心 #include ...
- CodeForces 548D 单调栈
Mike and Feet Time Limit:1000MS Memory Limit:262144KB 64bit IO Format:%I64d & %I64u Subm ...
- HDOJ 4252 A Famous City 单调栈
单调栈: 维护一个单调栈 A Famous City Time Limit: 10000/3000 MS (Java/Others) Memory Limit: 32768/32768 K (J ...
- Codeforces548D:Mike and Feet(单调栈)
Mike is the president of country What-The-Fatherland. There are n bears living in this country besid ...
- Imbalanced Array CodeForces - 817D (思维+单调栈)
You are given an array a consisting of n elements. The imbalance value of some subsegment of this ar ...
- Educational Codeforces Round 23 D. Imbalanced Array 单调栈
D. Imbalanced Array time limit per test 2 seconds memory limit per test 256 megabytes input standard ...
- 【CF671E】Organizing a Race 单调栈+线段树
[CF671E]Organizing a Race 题意:n个城市排成一排,每个城市内都有一个加油站,赛车每次经过第i个城市时都会获得$g_i$升油.相邻两个城市之间由道路连接,第i个城市和第i+1个 ...
- spoj MINSUB 单调栈+二分
题目链接:点击传送 MINSUB - Largest Submatrix no tags You are given an matrix M (consisting of nonnegative i ...
- Codeforces Round #305 (Div. 1) B. Mike and Feet 单调栈
B. Mike and Feet Time Limit: 20 Sec Memory Limit: 256 MB 题目连接 http://codeforces.com/contest/547/pro ...
随机推荐
- RocketMQ可视化控制台
中午文档 https://github.com/apache/rocketmq-externals/blob/master/rocketmq-console/doc/1_0_0/UserGuide_C ...
- zoolkeeper 的Curator的分布式锁
RetryPolicy retryPolicy = new ExponentialBackoffRetry(1000, 3) CuratorFramework client = CuratorFram ...
- mfc 常用的知识点
在MFC中引入了文档-视结构的概念,文档相当于数据容器,视相当于查看数据的窗口或是和数据发生交互的窗口.因此一个完整的应用一般由四个类组成:CWinApp应用类,CFrameWnd窗口框架类,CDoc ...
- C#基础知识---is与as
一.is与as对比 is检查一个对象是否兼容于指定的类型,并返回一个Boolean值:true或者fasle. 注:is操作符永远不会抛出异常 经常按如下方法使用: ClassA { .... } O ...
- 连接共享打印机失败错误代码0x80070035
局域网内共享打印机非常方便,但是在连接中经常遇到问题,其中出现错误代码0x80070035的概率非常之高! 1.必须确保有关打印功能的相关服务都处于自动启动状态,重点检查TCP/IP NetBIOS ...
- 关于windows下 python3安装 cython的说明
针对python3.6希望在windows环境下安装cython,但是网上任何关于mingw的尝试都没有生效.所以只能下载 vs, 1.去官网https://visualstudio.microsof ...
- 网络流量预测入门(三)之LSTM预测网络流量
目录 网络流量预测入门(三)之LSTM预测网络流量 数据集介绍 预测流程 数据集准备 SVR预测 LSTM 预测 优化点 网络流量预测入门(三)之LSTM预测网络流量 在上篇博客LSTM机器学习生成音 ...
- redis连接池 go-redis
为什么使用连接池? 首先Redis也是一种数据库,它基于C/S模式,因此如果需要使用必须建立连接,稍微熟悉网络的人应该都清楚地知道为什么需要建立连接,C/S模式本身就是一种远程通信的交互模式,因此Re ...
- 25道经典Java算法题
题目:古典问题:有一对兔子,从出生后第3个月起每个月都生一对兔子,小兔子长到第三个月后每个月又生一对兔子,假如兔子都不死,问每个月的兔子总数为多少? //这是一个菲波拉契数列问题 [Java] 纯 ...
- Learning to Compare: Relation Network for Few-Shot Learning 论文笔记
主要原理: 和Siamese Neural Networks一样,将分类问题转换成两个输入的相似性问题. 和Siamese Neural Networks不同的是: Relation Network中 ...