斜率优化 DP
CF311B Cats Transport
暑假到现在终于过了这道题.
首先计算出\(A[]\),\(A[i]\)表示如果有一个饲养员在\(A[i]\)时刻出发,那么刚好使第\(i\)只猫无需等待地被接走.
发现\(A[]\)与猫的编号无关,对其排序并求前缀和\(S[]\).
设\(F[i,j]\)表示前\(i\)个饲养员接走了前\(j\)只猫的最小等待时间和.
朴素算法有:
分别枚举\(i,j,k\),时间复杂度\(O(n^3)\).
考虑对最内层DP进行斜率优化,此时把与\(i,j\)相关的式子视为常量,把\(k\)视为变量,去掉\(\min\)函数,把状态转移方程变形,有:
令:
那么有\(y=A[j]\times x+b\)
容易发现这是一个一次函数,一但\(x\)确定,则可以在坐标轴中画出对应的点.换句话说,每一个\(k\)对应的是一个点.这些点的横坐标是单增的,因为\(j\)是从\(1...m\)的.
我们想让\(F[i,j]\)最小,就是让\(b\)最小,也就是让纵截距最小.而斜率\(A[j]\)是确定的显然在所有点中,只有下凸壳上的点可能使纵截距出现最小值.所以我们维护下凸壳.
下凸壳上的哪个点会使纵截距出现最小值呢?如果记\(slope(i,j)\)表示点\(i\)与点\(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的更多相关文章
- bzoj-4518 4518: [Sdoi2016]征途(斜率优化dp)
题目链接: 4518: [Sdoi2016]征途 Description Pine开始了从S地到T地的征途. 从S地到T地的路可以划分成n段,相邻两段路的分界点设有休息站. Pine计划用m天到达T地 ...
- bzoj-1096 1096: [ZJOI2007]仓库建设(斜率优化dp)
题目链接: 1096: [ZJOI2007]仓库建设 Description L公司有N个工厂,由高到底分布在一座山上.如图所示,工厂1在山顶,工厂N在山脚.由于这座山处于高原内陆地区(干燥少雨),L ...
- [BZOJ3156]防御准备(斜率优化DP)
题目:http://www.lydsy.com:808/JudgeOnline/problem.php?id=3156 分析: 简单的斜率优化DP
- 【BZOJ-1096】仓库建设 斜率优化DP
1096: [ZJOI2007]仓库建设 Time Limit: 10 Sec Memory Limit: 162 MBSubmit: 3719 Solved: 1633[Submit][Stat ...
- BZOJ 1010: [HNOI2008]玩具装箱toy 斜率优化DP
1010: [HNOI2008]玩具装箱toy Description P教授要去看奥运,但是他舍不下他的玩具,于是他决定把所有的玩具运到北京.他使用自己的压缩器进行压缩,其可以将任意物品变成一堆,再 ...
- BZOJ 3156: 防御准备 斜率优化DP
3156: 防御准备 Description Input 第一行为一个整数N表示战线的总长度. 第二行N个整数,第i个整数表示在位置i放置守卫塔的花费Ai. Output 共一个整数,表示最小的战 ...
- HDU2829 Lawrence(斜率优化dp)
学了模板题之后上网搜下斜率优化dp的题目,然后就看到这道题,知道是斜率dp之后有思路就可以自己做不出来,要是不事先知道的话那就说不定了. 题意:给你n个数,一开始n个数相邻的数之间是被东西连着的,对于 ...
- HDU3507 Print Article(斜率优化dp)
前几天做多校,知道了这世界上存在dp的优化这样的说法,了解了四边形优化dp,所以今天顺带做一道典型的斜率优化,在百度打斜率优化dp,首先弹出来的就是下面这个网址:http://www.cnblogs. ...
- HDU 3507 Print Article(斜率优化DP)
题目链接 题意 : 一篇文章有n个单词,如果每行打印k个单词,那这行的花费是,问你怎么安排能够得到最小花费,输出最小花费. 思路 : 一开始想的简单了以为是背包,后来才知道是斜率优化DP,然后看了网上 ...
- 斜率优化dp(POJ1180 Uva1451)
学这个斜率优化dp却找到这个真心容易出错的题目,其中要从n倒过来到1的确实没有想到,另外斜率优化dp的算法一开始看网上各种大牛博客自以为懂了,最后才发现是错了. 不过觉得看那些博客中都是用文字来描述, ...
随机推荐
- jni 文件切割合并
最近学习c++,看到很多常用的例子,比如文件切割,切割后后缀可以自定义,别人就无法从表面的一个文件看出是什么,也无法查看到原文件信息,只有合并后才能识别这庐山真面目 实现也比较粗暴,首先在应用层定义好 ...
- 记一个开发是遇到的坑之Oralce 字符串排序
简单描述一下情况,就是存储过程中用一个字符串类型的字段作为患者就诊的排序号,结果莫名发现叫完1号后叫了11.12等患者.用户的反馈不一定准确,自己加了日志的,赶紧拷贝日志来观察一下.结果发现实际情况就 ...
- Android中动态改变Listview中字体的颜色
效果如下: 账目显示用的是Listview,要实现的功能为使其根据所在Item是“收入”还是“支出”来把数字设置成绿色或红色 方法是自定义适配器,并重写其中getView()函数,实现如下: //自定 ...
- python基础扩展
一.垃圾回收机制 垃圾回收机制是自动帮助我们管理内存,清理垃圾的一种工具 1.引用计数 当一个对象的引用被创建或者复制时,对象的引用计数加1: 当一个对象的引用被销毁时,对象的引用计数减1: 当对象的 ...
- Couchdb垂直权限绕过到命令执行
0x00couchdb简介 Apache CouchDB是一个开源数据库,专注于易用性和成为"完全拥抱web的数据库".它是一个使用JSON作为存储格式,JavaScript作为查 ...
- JavaSE学习笔记(12)---线程
JavaSE学习笔记(12)---线程 多线程 并发与并行 并发:指两个或多个事件在同一个时间段内发生. 并行:指两个或多个事件在同一时刻发生(同时发生). 在操作系统中,安装了多个程序,并发指的是在 ...
- Spring Mvc Http 400 Bad Request问题排查
如果遇到了Spring MVC报错400,而且没有返回任何信息的情况下该如何排查问题? 问题描述 一直都没毛病的接口,今天测试的时候突然报错400 Bad Request,而且Response没有返回 ...
- 【Git】git使用 - 各种常用场景命令解决
(多看git中的各种帮助-h/--help,可能有你想要的命令) 1.分支的创建和切换 创建 >>>> git branch branchName 切换分支 >>& ...
- Vue中在template标签中进行判断时注意比较元素
(一)比较的元素,一个是data元素,另外一个是常量,如下图所示: 编译正常,运行正常,效果在期望中,会显示Hello World,结果如下: (二)比较的元素,一个是data元素,另外一个是cons ...
- Tunnel Warfare HDU - 1540
#include<iostream> #include<cstdio> #include<cstring> #include<algorithm> us ...