CF311B Cats Transport

暑假到现在终于过了这道题.

首先计算出\(A[]\),\(A[i]\)表示如果有一个饲养员在\(A[i]\)时刻出发,那么刚好使第\(i\)只猫无需等待地被接走.

发现\(A[]\)与猫的编号无关,对其排序并求前缀和\(S[]\).

设\(F[i,j]\)表示前\(i\)个饲养员接走了前\(j\)只猫的最小等待时间和.

朴素算法有:

\[F[i,j]=\min_{k<j}(F[i-1,k]+A[j]\times (j-k)-(S[j]-S[i])) \]

分别枚举\(i,j,k\),时间复杂度\(O(n^3)\).

考虑对最内层DP进行斜率优化,此时把与\(i,j\)相关的式子视为常量,把\(k\)视为变量,去掉\(\min\)函数,把状态转移方程变形,有:

\[F[i-1,k]+S[k]=A[j]\times k+F[i,j]-A[j]\times j+S[j] \]

令:

\[y=F[i-1,k]+S[k] \]
\[x=k \]
\[b=F[i,j]-A[j]\times j+S[j] \]

那么有\(y=A[j]\times x+b\)

容易发现这是一个一次函数,一但\(x\)确定,则可以在坐标轴中画出对应的点.换句话说,每一个\(k\)对应的是一个点.这些点的横坐标是单增的,因为\(j\)是从\(1...m\)的.

我们想让\(F[i,j]\)最小,就是让\(b\)最小,也就是让纵截距最小.而斜率\(A[j]\)是确定的显然在所有点中,只有下凸壳上的点可能使纵截距出现最小值.所以我们维护下凸壳.

下凸壳上的哪个点会使纵截距出现最小值呢?如果记\(slope(i,j)\)表示点\(i\)与点\(j\)连线的斜率,那么:

\[slope(i-1,i)<=A[j],slope(i,i+1)>=A[j](*) \]

的点会使纵截距出现最小值.

本题中,\(A[j]\)单增,所以可以用单调队列维护这个下凸壳.队首出队的条件是:队首两点间斜率\(<A[j]\),因为\(A[j]\)单增,而这两点斜率又\(<A[j]\),那么队首的点无论如何不可能成为满足\(*\)式的最优情况.

从队尾入队的条件是:能形成下凸壳.

#include<bits/stdc++.h>
const int SIZE=100005; int In()
{
char ch=getchar();
int x=0;
while(ch<'0'||ch>'9')ch=getchar();
while(ch>='0'&&ch<='9'){x=x*10+ch-'0';ch=getchar();}
return x;
} int n,m,p,h,Tim,sum_D[SIZE];
int A[SIZE];
long long DP[105][SIZE],sum_A[SIZE];
int q[SIZE],L,R; int main()
{
scanf("%d%d%d",&n,&m,&p);
for(int i=2;i<=n;i++)
sum_D[i]=sum_D[i-1]+In();
for(int i=1;i<=m;i++)
{
h=In();Tim=In();
A[i]=Tim-sum_D[h];
}
std::sort(A+1,A+1+m);
for(int i=1;i<=m;i++)sum_A[i]=sum_A[i-1]+A[i];
memset(DP,0x3F,sizeof(DP));
DP[0][0]=0;
for(int i=1;i<=p;i++)
{
L=R=1;
q[1]=0;
#define G(x) (DP[i-1][x]+sum_A[x])
#define S(A,B) (double)(G(B)-G(A))/(double)(B-A)
for(int k=1;k<=m;k++)
{
while( L<R && S(q[L],q[L+1]) <= 1.0*A[k] )L++;
DP[i][k]=DP[i-1][q[L]]+1LL*A[k]*(k-q[L])-(sum_A[k]-sum_A[q[L]]);
while( L<R && S(q[R-1],q[R]) >= S(q[R],k) )R--;
q[++R]=k;
}
}
std::cout<<DP[p][m];
return 0;
}

斜率优化 DP的更多相关文章

  1. bzoj-4518 4518: [Sdoi2016]征途(斜率优化dp)

    题目链接: 4518: [Sdoi2016]征途 Description Pine开始了从S地到T地的征途. 从S地到T地的路可以划分成n段,相邻两段路的分界点设有休息站. Pine计划用m天到达T地 ...

  2. bzoj-1096 1096: [ZJOI2007]仓库建设(斜率优化dp)

    题目链接: 1096: [ZJOI2007]仓库建设 Description L公司有N个工厂,由高到底分布在一座山上.如图所示,工厂1在山顶,工厂N在山脚.由于这座山处于高原内陆地区(干燥少雨),L ...

  3. [BZOJ3156]防御准备(斜率优化DP)

    题目:http://www.lydsy.com:808/JudgeOnline/problem.php?id=3156 分析: 简单的斜率优化DP

  4. 【BZOJ-1096】仓库建设 斜率优化DP

    1096: [ZJOI2007]仓库建设 Time Limit: 10 Sec  Memory Limit: 162 MBSubmit: 3719  Solved: 1633[Submit][Stat ...

  5. BZOJ 1010: [HNOI2008]玩具装箱toy 斜率优化DP

    1010: [HNOI2008]玩具装箱toy Description P教授要去看奥运,但是他舍不下他的玩具,于是他决定把所有的玩具运到北京.他使用自己的压缩器进行压缩,其可以将任意物品变成一堆,再 ...

  6. BZOJ 3156: 防御准备 斜率优化DP

    3156: 防御准备 Description   Input 第一行为一个整数N表示战线的总长度. 第二行N个整数,第i个整数表示在位置i放置守卫塔的花费Ai. Output 共一个整数,表示最小的战 ...

  7. HDU2829 Lawrence(斜率优化dp)

    学了模板题之后上网搜下斜率优化dp的题目,然后就看到这道题,知道是斜率dp之后有思路就可以自己做不出来,要是不事先知道的话那就说不定了. 题意:给你n个数,一开始n个数相邻的数之间是被东西连着的,对于 ...

  8. HDU3507 Print Article(斜率优化dp)

    前几天做多校,知道了这世界上存在dp的优化这样的说法,了解了四边形优化dp,所以今天顺带做一道典型的斜率优化,在百度打斜率优化dp,首先弹出来的就是下面这个网址:http://www.cnblogs. ...

  9. HDU 3507 Print Article(斜率优化DP)

    题目链接 题意 : 一篇文章有n个单词,如果每行打印k个单词,那这行的花费是,问你怎么安排能够得到最小花费,输出最小花费. 思路 : 一开始想的简单了以为是背包,后来才知道是斜率优化DP,然后看了网上 ...

  10. 斜率优化dp(POJ1180 Uva1451)

    学这个斜率优化dp却找到这个真心容易出错的题目,其中要从n倒过来到1的确实没有想到,另外斜率优化dp的算法一开始看网上各种大牛博客自以为懂了,最后才发现是错了. 不过觉得看那些博客中都是用文字来描述, ...

随机推荐

  1. F12后面的世界(Elements篇)——重识html

    从 淘宝网, 检查元素开始探索之旅. html是什么? hyper text markup language 超文本标记语言,使用标签来描述网页 标签 语义化标签 html5新增标签 什么是超文本? ...

  2. leetcode-简单-栈-逆波兰表达式

    根据逆波兰表示法,求表达式的值. 有效的运算符包括 +, -, *, / .每个运算对象可以是整数,也可以是另一个逆波兰表达式. 说明:  整数除法只保留整数部分. 给定逆波兰表达式总是有效的.换句话 ...

  3. STM32之RGB灯仿真

    实验目的 点灯是练习GPIO输出的最佳实验.由于疫情期间没法返校,手头上没有现成的实验板,于是借助Proteus进行仿真.本实验点的不是普通的灯,而是RGB混色灯,实现多种颜色的显示.后期还可以加上P ...

  4. AB实验人群定向HTE模型5 - Meta Learner

    Meta Learner和之前介绍的Casual Tree直接估计模型不同,属于间接估计模型的一种.它并不直接对treatment effect进行建模,而是通过对response effect(ta ...

  5. python基础入门之一 —— 变量与运算符

    1.标识符 由数字,字母,下划线组成 不能由数字开头 不能使用内置关键字 严格区分大小 2.数据类型 数值:int (整型) float(浮点型) 布尔型:True(真) False(假) str ( ...

  6. php ip转换省市县

    http://www.cz88.net/ip/ http://www.ttlsa.com/php/php_cunzhen-ipdata/ # wget h http://6.scdx3.crsky.c ...

  7. navicate premium连接sqlserver时报08001错误的解决方法

    ---恢复内容开始--- navicate premium连接sqlserver时报08001错误的解决方法 1.自己一直使用navicate连接sqlserver,但是自从自己的电脑安装了sqlse ...

  8. 浅谈python的第三方库——pandas(三)

    令笔者对pandas印象最为深刻的一件事,就是在pandas中已经内置了很多数据导入导出方法,然而本人并不了解,在一次小项目的工作中曾手写了一个从excel表格导入数据到DataFrame的pytho ...

  9. WebDev.WebServer20.exe应用程序错误

    我的.net网页,在iis运行成功,在VS2010调试网页时报一个WebDev.WebServer20.exe应用程序错误. 最后查找资料,发现了网站设置的框架是2.0,在vs2010里不能调试2.0 ...

  10. 腾讯云nginx配置https

    给腾讯nginx服务器配置https, 之前申请https配置后直接给node配置了,还没有用nginx. 按照 https://cloud.tencent.com/document/product/ ...