题解 CF311B Cats Transport
前置芝士:斜率优化
剥下这道题的外壳,让它变为一道裸的斜率优化。
很容易想到状态,但复杂度显然过不去,也没有单调性,只能自己创造。
令
$$c[i] = t - sum[i],sum[i] = \sum_{j = 1} ^{i} d[j]$$
如果出发时间为t,那么 t - c[i] 即是等待时间
将 c 数组排序后,带走其中一个即可以带走旁边几个,那就是变成了连续选择,c排序后有了单调性,那么转移式就成了
dp[k][i]表示第 k 个饲养员,到 i 这个地方取猫的最小代价
$$dp[k][i] = min(dp[k - 1][j] + \sum_{t = j + 1}^ic[i] - c[t])(j \le i )$$
发现之中有前缀和
令
$$S_i = \sum_{t = 1}^ic[t]$$
那么化简式子后就成了一个标准的斜率优化
$$dp[k - 1][j] + S_j = c[i] * j + dp[k][i] - c[i] * i$$
具体实现不懂的
#include<bits/stdc++.h> using namespace std;
#define N 100001
long long f[101][N];
struct node {
int k,las;
}p[N * 101];
int l = 1,r = 0;
int n,m,q;
long long sumd[N];
struct cats {
long long a,sum;
}c[N];
bool cmp(cats x,cats y) {
return x.a < y.a;
}
inline bool checkhead(int x1,int x2,int pos,int peo) {
if(l + 1 > r) return false;
peo--;
if(f[peo][x2] - f[peo][x1] + c[x2].sum - c[x1].sum <= (x2 - x1) * c[pos].a) return true;
return false;
}
inline bool check(int x1,int x2,int pos,int peo) {
if(r - 1 < l) return false;
peo--;
if((f[peo][x2] - f[peo][x1] + c[x2].sum - c[x1].sum) * (pos - x2) <= (f[peo][pos] - f[peo][x2] + c[pos].sum - c[x2].sum) * (x2 - x1)) {
return true;
}
return false;
}
int main() {
scanf("%d %d %d", &n, &m, &q);
for(int i = 2;i <= n;i++) {
scanf("%d", &sumd[i]);
sumd[i] += sumd[i - 1];
}
for(int i = 1;i <= m;i++) {
int pos,t;
scanf("%d %d", &pos, &t);
c[i].a = t - sumd[pos];
}
int cnt = 0;
sort(c + 1,c + m + 1,cmp);
for(int i = 1;i <= m;i++) {
c[i].sum = c[i - 1].sum + c[i].a;
}
for(int i = 1;i <= m;i++) {
f[1][i] = i * c[i].a - c[i].sum;
}
f[0][0] = 0;
for(int i = 2;i <= q;i++) {
l = 1,r = 0;
p[++r].k = 0;
c[0].a = 0,c[0].sum = 0;
for(int j = 1;j <= m;j++) {
while(l <= r && checkhead(p[l].k,p[l + 1].k,j,i)) {
l++;
}
int k = p[l].k;
f[i][j] = f[i - 1][k] + c[k].sum + c[j].a * j - c[j].a * k - c[j].sum;
while(l <= r && check(p[r].k,p[r - 1].k,j,i)) {
r--;
}
p[++r].k = j;
}
}
cout<<f[q][m];
return 0;
}
题解 CF311B Cats Transport的更多相关文章
- CF311B Cats Transport 斜率优化DP
题面:CF311B Cats Transport 题解: 首先我们观察到山与距离其实是没有什么用的,因为对于任意一只猫,我们都可以直接算出如果有一个人要恰好接走它,需要在哪一时刻出发,我们设第i只猫对 ...
- 【题解】Cats Transport (斜率优化+单调队列)
[题解]Cats Transport (斜率优化+单调队列) # When Who Problem Lang Verdict Time Memory 55331572 Jun/09/2019 19:1 ...
- CF311B Cats Transport
题意 Zxr960115 is owner of a large farm. He feeds m cute cats and employs p feeders. There's a straigh ...
- CF311B Cats Transport(斜率优化)
题目描述 Zxr960115 是一个大农场主.他养了m只可爱的猫子,雇佣了p个铲屎官.这里有一条又直又长的道路穿过了农场,有n个山丘坐落在道路周围,编号自左往右从1到n.山丘i与山丘i-1的距离是Di ...
- $CF311B\ Cats\ Transport$ 斜率优化
AcWing Description Sol 设f[i][j]表示前i个饲养员接走前j只猫咪的最小等待时间. 要接到j猫咪,饲养员的最早出发时间是可求的,设为d: $ d[j]=Tj-\sum_{k= ...
- CF-311B Cats Transport(斜率优化DP)
题目链接 题目描述 小S是农场主,他养了 \(M\)只猫,雇了 \(P\) 位饲养员. 农场中有一条笔直的路,路边有 \(N\) 座山,从 \(1\) 到 \(N\)编号. 第 \(i\) 座山与第 ...
- 题解-Cats Transport
题解-Cats Transport Cats Transport 有 \(n\) 个山丘,\(m\) 只猫子,\(p\) 只铲屎官.第 \(i-1\) 个山丘到第 \(i\) 个山丘的距离是 \(d_ ...
- 笔记-Cats Transport<已写题解>
笔记-Cats Transport Cats Transport 令 \(D_i=\sum_{j=1}^id_i\),\(T_i=t_i-D_{h_i}\). 为 \(T_i\) 从小到大排序,令 \ ...
- 一本通1609【例 4】Cats Transport
1609:[例 4]Cats Transport 时间限制: 1000 ms 内存限制: 524288 KB sol:非常偷懒的截图了事 注意:只能猫等人,不能人等猫 对于每只猫,我们 ...
随机推荐
- 记一次zabbix-server故障恢复导致的事故 zabbix-server.log -- One child process died
前言 zabbix-server昨天出了个问题,不停的重启.昨天摆弄到晚上也不搞清楚原因,按照网上说的各种操作,各种CacheSize.TimeOut.StartPollers都改了,还有什么Incl ...
- AI推理与Compiler
AI推理与Compiler AI芯片编译器能加深对AI的理解, AI芯片编译器不光涉及编译器知识,还涉及AI芯片架构和并行计算如OpenCL/Cuda等.如果从深度学习平台获得IR输入,还需要了解深度 ...
- MCU,硅片,BOM
MCU,硅片,BOM BOM(Bill of Material,物料清单),就是指一个东西的各个材料的的成本价格 BOM成本要控制,有三点要注意的. 一,是否有芯片替代料,在性能不降低的情况下,替代料 ...
- NVIDIA FFmpeg 转码技术分析
NVIDIA FFmpeg 转码技术分析 所有从 Kepler 一代开始的 NVIDIA GPUs 都支持完全加速的硬件视频编码,而从费米一代开始的所有 GPUs 都支持完全加速的硬件视频解码.截至 ...
- h265player开发
h265player开发 https://github.com/goldvideo/h265player 简介 随着视频编码技术的发展,相比H.264, H.265同等画质体积仅为一半.带宽占用省一半 ...
- JDBCTemplate基本使用
用了jdbc连接池之后,我们会发现连接对象的复用性更高了,程序整体运行的性能也更高了.但是我们在做JDBC操作的时候还是比较麻烦,要定义sql,执行sql,设置参数,处理结果. 特别是当我们要做查询操 ...
- UF_MODL 建模操作
Open C uc6560 uf5300uf5301uf5303uf5305uf5309uf5310uf5311uf5313uf5315uf5317uf5319uf5320uf5321uf5323uf ...
- 【Azure 机器人】微软Azure Bot 编辑器系列(6) : 添加LUIS,理解自然语言 (The Bot Framework Composer tutorials)
欢迎来到微软机器人编辑器使用教程,从这里开始,创建一个简单的机器人. 在该系列文章中,每一篇都将通过添加更多的功能来构建机器人.当完成教程中的全部内容后,你将成功的创建一个天气机器人(Weather ...
- 你有一份经典SQL语句大全,请注意查收
一.基础部分 1.创建数据库 CREATE DATABASE dbname 2.删除数据库 DROP DATABASE dbname 3.创建新表 CREATE TABLE tabname(col1 ...
- 你应该这样去开发接口:Java多线程并行计算
所谓的高并发除了在架构上的高屋建瓴,还得需要开发人员在具体业务开发中注重自己的每一行代码.每一个细节,面子有的同时,更重要的还是要有里子. 面对性能,我们一定要有自己的工匠精神,不可以对任何一行代码妥 ...