正题

题目链接:https://www.luogu.com.cn/problem/P7294


题目大意

\(n\times m\)的网格,当你在\((x,y)\)时你有两种选择

  1. 花费\(x^2\)的代价向右移动
  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【单调栈】的更多相关文章

  1. [Agc005D/At2060] Minimum Sum - 单调栈

    鉴于早上那题让我怀疑单调栈白学,特意来复习下单调栈 题意 考虑按照每个元素对答案的贡献来统计,那么我们只需要找到每个元素左边右边第一个比它小的就可 这题给的又是排列,简直不能再良心 #include ...

  2. CodeForces 548D 单调栈

    Mike and Feet Time Limit:1000MS     Memory Limit:262144KB     64bit IO Format:%I64d & %I64u Subm ...

  3. HDOJ 4252 A Famous City 单调栈

    单调栈: 维护一个单调栈 A Famous City Time Limit: 10000/3000 MS (Java/Others)    Memory Limit: 32768/32768 K (J ...

  4. Codeforces548D:Mike and Feet(单调栈)

    Mike is the president of country What-The-Fatherland. There are n bears living in this country besid ...

  5. Imbalanced Array CodeForces - 817D (思维+单调栈)

    You are given an array a consisting of n elements. The imbalance value of some subsegment of this ar ...

  6. Educational Codeforces Round 23 D. Imbalanced Array 单调栈

    D. Imbalanced Array time limit per test 2 seconds memory limit per test 256 megabytes input standard ...

  7. 【CF671E】Organizing a Race 单调栈+线段树

    [CF671E]Organizing a Race 题意:n个城市排成一排,每个城市内都有一个加油站,赛车每次经过第i个城市时都会获得$g_i$升油.相邻两个城市之间由道路连接,第i个城市和第i+1个 ...

  8. spoj MINSUB 单调栈+二分

    题目链接:点击传送 MINSUB - Largest Submatrix no tags  You are given an matrix M (consisting of nonnegative i ...

  9. 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 ...

随机推荐

  1. join控制线程的执行循序 T1 -> T2 -> T3

    /** * 控制线程的执行循序 T1 -> T2 -> T3 * join实现 */ public static void join(){ Thread t1 = new Thread(( ...

  2. C++ 中的User a, User b=a 和User a, User b, b=a的区别

    #include <iostream>using namespace std;class User{ public: int age; int number; User() { cout ...

  3. QT 中的QTableWidget

  4. plsql developer中各个window的作用【转】

    转载自,原文链接: -程序窗口(program window) :可以执行 sql,sqlplus 相关的语句,例如存储过程,方法,一般用来开发程序用的. -测试窗口(test window):一般是 ...

  5. JDBC中级篇(MYSQL)——处理大文本(CLOB)

    注意:其中的JdbcUtil是我自定义的连接工具类:代码例子链接: package b_blob_clob; import java.io.FileNotFoundException; import ...

  6. 小程序跨页面传递data数据的三种方法

    Q:小程序怎么把页面data里的数据传到另外的页面? 或者小程序怎么吧表单里的数据传到另外的页面?A:1.可以使用url传递数据. 例如在A页面中传递数据,需要注意的是,wx.switchTab中的u ...

  7. 将VSCode添加至右键菜单(Windows下)

    时间:2018-11-09 记录:byzqy 问题: Windows上面安装Visual Studio Code编辑器后,常常会因为安装的时候忘记勾选等原因,没有将"Open with Co ...

  8. 30 道 Vue 面试题,内含详细讲解(涵盖入门到精通,自测 Vue 掌握程度)

    前言 本文以前端面试官的角度出发,对 Vue 框架中一些重要的特性.框架的原理以问题的形式进行整理汇总,意在帮助作者及读者自测下 Vue 掌握的程度.本文章节结构以从易到难进行组织,建议读者按章节顺序 ...

  9. html调用swf的语句

    <div style="width: 1000px; height: 202px; margin-left: auto; margin-right: auto"> &l ...

  10. 如何攻击Java Web应用

    越来越多的企业采用Java语言构建企业Web应用程序,基于Java主流的框架和技术及可能存在的风险,成为被关注的重点. 本文从黑盒渗透的角度,总结下Java Web应用所知道的一些可能被利用的入侵点. ...