【题解】Cats Transport (斜率优化+单调队列)
【题解】Cats Transport (斜率优化+单调队列)
| # | When | Who | Problem | Lang | Verdict | Time | Memory |
|---|---|---|---|---|---|---|---|
| 55331572 | Jun/09/2019 19:18UTC+8 | Winlere | D - Cats Transport | GNU C++11 | Accepted | 405 ms | 84200 KB |
思考的过程很艰难,想清楚之后就不难做了。记录一下思路过程。
| 时间 | 事件 |
|---|---|
| 14:00 | 开始审题 |
| 14:15 | 手玩样例 |
| 14:30 | Observe \(\times 1\):一个喂养员喂连续的一片 |
| 14:50 | Observe\(\times2\):一个喂养员喂的连续的一片一定是按照\(t(i)-dis(1,h_i)\)的升序最优 |
| 15:00 | Brute Force\(\times 1\): \(O(n^2)\)DP,\(dp(i,j)\)考虑了\(i\)个喂养员,带回前\(j\)只猫(按照\(t(i)-dis(1,h_i)\)排序) |
| 15:30 | Debug \(\times 1\): \(t(i)-dis(1,h_i)\)不需要对\(0\)取\(max\) |
| 16:30 | Solution\(\times 1\) 单调队列 |
| 16:50 | Solution\(\times2\) 斜率优化+单调队列 |
| 吃饭 | 差点被阿 |
| 19:18 | Accepted |
想的时间占了很多,幸运的是一开始的\(O(n^2)\)DP的方向是对的,一个小时写出暴力还是很赚的。就是后面想什么单调队列,应该可以直接想到斜率优化的,\(n^2\)转\(n \log n\)太常见了。
有两个Observe比较显然就不证明了。\(t_i-dis(1,i)\)可以代表的含义是喂养员最早出来的时刻。
\(O(n^2)\)的转移:
\\
sum(i)=\Sigma_{j=1}^it_j-dis(1,j)
\]
拆开\(j,k\)直接变成一个斜率优化的套路式。
\(x_k=k,y_k=dp(i-1,k)+sum(k)\)
原式变为:
\]
查询一个截距最小值。好像要单调队列维护。查到哪个\(k\)转移套到原式就好了。
不过这里复杂度貌似\(O(n)(k\le 100)\)
//@winlere
#include<iostream>
#include<cstdio>
#include<cstring>
#include<algorithm>
#include<queue>
using namespace std; typedef long long ll;
inline ll qr(){
register ll ret=0,f=0;
register char c=getchar();
while(c<48||c>57)f|=c==45,c=getchar();
while(c>=48&&c<=57) ret=ret*10+c-48,c=getchar();
return f?-ret:ret;
}
const int maxn=1e5+5;
int n,m,p;
int dis[maxn];
ll sumd[maxn];
ll sumdata[maxn];
ll x[maxn];
ll y[maxn];
ll dp[101][maxn];
struct NODE{
int pos,time;
ll limit;
NODE(){limit=pos=time=0;}
inline bool operator <(const NODE&a)const{return limit<a.limit;}
inline void scan(){
pos=qr();time=qr();
limit=time-sumd[pos];
}
}data[maxn];
typedef deque<int>::iterator it;
deque < int > q;
int main(){
n=qr();m=qr();p=qr();
for(register int t=2;t<=n;++t)
sumd[t]=(dis[t]=qr())+sumd[t-1];
for(register int t=1;t<=m;++t)
data[t].scan();
sort(data+1,data+m+1);
for(register int t=1;t<=m;++t) sumdata[t]=data[t].limit+sumdata[t-1];
memset(dp,5,sizeof dp);
dp[0][0]=0;
it ita;
for(register int i=0;i<=m;++i)
x[i]=i;
for(register int t=1;t<=p;++t){
for(register int i=0;i<=m;++i){
dp[t][i]=dp[t-1][i];
y[i]=dp[t-1][i]+sumdata[i];
}
q.clear();
for(register int i=1;i<=m;++i){
q.push_back(i-1);
ita=q.begin();
while(q.size()>1&&y[*(ita+1)]-y[*ita]<=1ll*data[i].limit*((*(ita+1))-(*ita))) q.pop_front(),ita=q.begin();
register int j=q.front();
dp[t][i]=min(dp[t][i],dp[t-1][j]+1ll*(i-j)*data[i].limit-(sumdata[i]-sumdata[j]));
ita=q.end()-1;
while(q.size()>1&&(y[*ita]-1ll*y[*(ita-1)])*(i-(*ita))>=1ll*(y[i]-y[*ita])*((*ita)-(*(ita-1)))) q.pop_back(),ita=q.end()-1;;
}
}
cout<<dp[p][m]<<endl;
return 0;
}
【题解】Cats Transport (斜率优化+单调队列)的更多相关文章
- CF311B Cats Transport 斜率优化DP
题面:CF311B Cats Transport 题解: 首先我们观察到山与距离其实是没有什么用的,因为对于任意一只猫,我们都可以直接算出如果有一个人要恰好接走它,需要在哪一时刻出发,我们设第i只猫对 ...
- BZOJ.1010.[HNOI2008]玩具装箱toy(DP 斜率优化/单调队列 决策单调性)
题目链接 斜率优化 不说了 网上很多 这的比较详细->Click Here or Here //1700kb 60ms #include<cstdio> #include<cc ...
- Codeforces 311B Cats Transport 斜率优化dp
Cats Transport 出发时间居然能是负的,我服了... 卡了我十几次, 我一直以为斜率优化写搓了. 我们能得出dp方程式 dp[ i ][ j ] = min(dp[ k ][ j - 1 ...
- [bzoj1010](HNOI2008)玩具装箱toy(动态规划+斜率优化+单调队列)
Description P教授要去看奥运,但是他舍不下他的玩具,于是他决定把所有 的玩具运到北京.他使用自己的压缩器进行压缩,其可以将任意物品变成一堆,再放到一种特殊的一维容器中.P教授有编号为1.. ...
- CF331B Cats Transport[斜率优化dp+贪心]
luogu翻译 一些山距离起点有距离且不同,m只猫要到不同的山上去玩ti时间,有p个铲屎官人要去把所有猫接走,步行速度为1单位每秒,从1走到N座山不停下,必须在猫玩完后才可以把他带走.可以提前出发.问 ...
- CodeForces 311 B Cats Transport 斜率优化DP
题目传送门 题意:现在有n座山峰,现在 i-1 与 i 座山峰有 di长的路,现在有m个宠物, 分别在hi座山峰,第ti秒之后可以被带走,现在有p个人,每个人会从1号山峰走到n号山峰,速度1m/s.现 ...
- $CF311B\ Cats\ Transport$ 斜率优化
AcWing Description Sol 设f[i][j]表示前i个饲养员接走前j只猫咪的最小等待时间. 要接到j猫咪,饲养员的最早出发时间是可求的,设为d: $ d[j]=Tj-\sum_{k= ...
- LA-4726 (斜率优化+单调队列)
题意: 给定一个01序列,选一个长度至少为L 的连续子序列使其平均值最大;输出这个子序列的起点和终点;如果有多个答案,输出长度最小的,还有多个就输出第一个编号最小的; 思路: 用sum[i]表示[1, ...
- 题解-Cats Transport
题解-Cats Transport Cats Transport 有 \(n\) 个山丘,\(m\) 只猫子,\(p\) 只铲屎官.第 \(i-1\) 个山丘到第 \(i\) 个山丘的距离是 \(d_ ...
随机推荐
- Codeforces Round #490 (Div. 3)
感觉现在\(div3\)的题目也不错啊? 或许是我变辣鸡了吧....... 代码戳这里 A. Mishka and Contes 从两边去掉所有\(≤k\)的数,统计剩余个数即可 B. Reversi ...
- vue开发小程序简介
开发环境搭建 nodejs 安装最新版的nodejs,同时安装cnpm包管理器 jdk1.8 apache-maven3.3.9 Intellij Idea2018 [后端开发工具] vscode[前 ...
- mysql数据对象
学习目标: 了解掌握常见的几种数据库对象 学会如何创建具体的数据对象 mysql 常见的数据对象有哪些: DataBase/Schema Table Index View/Trigger/ ...
- iOS UI Element Usage
Bars The Status Bar
- z pre-pass 相关问题的讨论
z pre-pass 是指在渲染流程中,第一个pass先画一张深度buffer出来,得到需要绘制的最前面这层深度,用这个在接下来的pass中做深度剔出,这样在第二个pass中会省略很多绘制. 这项技术 ...
- 2017.2.20 activiti实战--第五章--用户与组及部署管理(一)用户与组
学习资料:<Activiti实战> 第五章 用户与组及部署管理(一)用户与组 内容概览:讲解activiti中内置的一套用户.组的关系,以及如何通过API添加.删除.查询. 5.1 用户与 ...
- C#反射获取属性值和设置属性值
/// /// 获取类中的属性值 /// public string GetModelValue(string FieldName, object obj) { try { Type Ts = obj ...
- HTML5 Canvas 绘制五角星
代码: <!DOCTYPE html> <html lang="utf-8"> <meta http-equiv="Content-Type ...
- Nginx学习——Nginx进程间的通信
nginx进程间的通信 进程间消息传递 共享内存 共享内存还是Linux下提供的最主要的进程间通信方式,它通过mmap和shmget系统调用在内存中创建了一块连续的线性地址空间,而通过munmap或者 ...
- [JS][jQuery]清空元素html("")、innerHTML="" 与 empty()的差别:关于内容泄露问题
清空元素html("").innerHTML="" 与 empty()的差别 一.清空元素的差别 1.错误做法一: $(&quo ...