传送门

简化题意

给你 \(m\) 个码头,码头之间有双向边连接,\(n\) 天,其中一些码头在某些天会不可用,这 \(n\) 天都要有一条从 \(1\) 到 \(m\) 的路,每一次更换道路会需要 \(k\) 的代价,求这 \(n\) 天每天从 \(1\) 到 \(m\) 的距离之和与更改道路的价值之和的最小值。

Solution

首先我们能想到一个贪心的策略:在保证最短路的同时,需要保证更换道路尽可能少。

然后0我们可以想到令 \(cost_{i,j}\) 为从第 \(i\) 天到第 \(j\) 天走同一条路径的最短长度和,\(f_i\) 为第 \(i\) 天的 \(ans\) 值,于是我们可以列出状态转移方程:

\[f_i\ =\ \min \\{ f_j + k + cost_{j + 1, i} \\}
\]

接下来,我们来处理 \(cost{i, j}\),我们发现只要 \(x\) 号码头在 \(i\) 到 \(j\) 天封闭过一次,在 \(i\) 到 \(j\) 天的路径里就不能选它,所以只需要在跑最短路时判一下 \(x\) 号点是否被封禁即可。

注:若 \(i\) 到 \(j\) 天不能从 \(1\) 走到 \(m\),就把 \(const_{i,j}\) 赋值为 \(INF\) 即可。

时间复杂度

约为 \(O(n^3m)\)

代码实现

#include<iostream>
#include<cstring>
#include<algorithm>
#include<queue>
using namespace std; #define int long long // 不开longlong见祖宗
const int Days = 105, N = 25, M = 405; int n, m, k, e, Q, x, y, w;
int la[N], en[M], ne[M], len[M], idx;
int dis[N], f[Days], cost[Days][Days];
bool st[N], lock[N], timlock[N][Days];
queue<int > q; void add(int x, int y, int z) {
en[ ++ idx] = y;
ne[idx] = la[x];
la[x] = idx;
len[idx] = z;
} void spfa(int l, int r) {
memset(dis, 0x3f3f3f3f, sizeof dis);
q.push(1), dis[1] = 0, st[1] = 1;
while(q.size()) {
int u = q.front();
st[u] = 0; q.pop();
for (int i = la[u]; i; i = ne[i]) {
int v = en[i];
if(lock[v]) continue;
if(dis[v] > dis[u] + len[i]) {
dis[v] = dis[u] + len[i];
if(!st[v]) {
q.push(v);
st[v] = 1;
}
}
}
}
cost[l][r] = (dis[m]>=0x3f3f3f3f3f3f3f3f ? 1 : r - l + 1) * dis[m];
} signed main(){
ios::sync_with_stdio(0); cin >> n >> m >> k >> e;
while(e -- ) {
cin >> x >> y >> w;
add(x, y, w); add(y, x, w); // 注意是双向边
}
cin >> Q;
while(Q -- ) {
cin >> w >> x >> y;
for (int i = x; i <= y; ++ i ) timlock[w][i] = 1; //打标记
} for (int i = 1; i <= n; ++ i )
for (int j = i; j <= n; ++ j ) {
for (int l = 1; l <= m; ++ l )
for (int tim = i; tim <= j; ++ tim ) {
lock[l] |= timlock[l][tim];
if(lock[l]) break;
}
spfa(i, j);
for (int l = 1; l <= m; ++ l ) lock[l] = 0; //记得清空
} for (int i = 1; i <= n; ++ i ) {
f[i] = cost[1][i]; //初始化为全用一条路
for (int j = 1; j < i; ++ j ) {
f[i] = min(f[i], f[j] + k + cost[j + 1][i]);
}
} cout << f[n];
return 0;
}

Luogu1772 [ZJOI2006] 物流运输的更多相关文章

  1. [luogu1772 ZJOI2006] 物流运输 (最短路 线性dp)

    题目描述 物流公司要把一批货物从码头A运到码头B.由于货物量比较大,需要n天才能运完.货物运输过程中一般要转停好几个码头.物流公司通常会设计一条固定的运输路线,以便对整个运输过程实施严格的管理和跟踪. ...

  2. [ZJOI2006]物流运输

    1003: [ZJOI2006]物流运输 Time Limit: 10 Sec  Memory Limit: 162 MBSubmit: 5999  Solved: 2473[Submit][Stat ...

  3. bzoj1003 [ZJOI2006]物流运输

    1003: [ZJOI2006]物流运输 Time Limit: 10 Sec  Memory Limit: 162 MBSubmit: 6300  Solved: 2597[Submit][Stat ...

  4. 【bzoj1003】[ZJOI2006]物流运输

    1003: [ZJOI2006]物流运输 Time Limit: 10 Sec  Memory Limit: 162 MBSubmit: 6331  Solved: 2610[Submit][Stat ...

  5. bzoj1003: [ZJOI2006]物流运输

    dp+最短路.暴力枚举就可以了.O(n3logn).样例中m=n然后测样例过了.然后 54行习惯性的dis[n]然后就WA了!!!. #include<cstdio> #include&l ...

  6. BZOJP1003 [ZJOI2006]物流运输trans

    BZOJP1003 [ZJOI2006]物流运输trans 1003: [ZJOI2006]物流运输trans Time Limit: 10 Sec  Memory Limit: 162 MB Sub ...

  7. BZOJ 1003 [ZJOI2006]物流运输trans

    1003: [ZJOI2006]物流运输trans Time Limit: 10 Sec  Memory Limit: 162 MBSubmit: 4242  Solved: 1765[Submit] ...

  8. bzoj1003[ZJOI2006]物流运输trans

    1003: [ZJOI2006]物流运输trans Description 物流公司要把一批货物从码头A运到码头B.由于货物量比较大,需要n天才能运完.货物运输过程中一般要转停好几个码头.物流公司通常 ...

  9. BZOJ 1003: [ZJOI2006]物流运输trans(最短路+dp)

    1A,爽! cost[i][j]表示从第i天到第j天不改路线所需的最小花费,这个可以用最短路预处理出.然后dp(i)=cost[j][i]+dp(j-1)+c. c为该路线的花费. --------- ...

  10. BZOJ_1003_[ZJOI2006]物流运输_最短路+dp

    BZOJ_1003_[ZJOI2006]物流运输_最短路+dp 题意:http://www.lydsy.com/JudgeOnline/problem.php?id=1003 分析: 这种一段一段的显 ...

随机推荐

  1. pytorch CrossEntropyLoss() 默认转换one-hot编码

    import torchpredict = torch.randn((4,3))predict = torch.nn.functional.softmax(predict,dim = 1)target ...

  2. 除select外查询数据的另一种姿势

    1.24 1.[GYCTF2020]Blacklist buuctf上的题目 1.解题过程 输入1会返回一个数组,加上单引号就报错了,说明存在注入 以前做过类似的估计是堆叠注入,尝试一下 注入成功 正 ...

  3. 把 ChatGPT 加入 Flutter 开发,会有怎样的体验?

    前言 ChatGPT 最近一直都处于技术圈的讨论焦点.它除了可作为普通用户的日常 AI 助手,还可以帮助开发者加速开发进度.声网社区的一位开发者"小猿"就基于 ChatGPT 做了 ...

  4. Maven安装详解

    Maven Maven是apache软件基金会旗下的一个开源项目,是一款用于管理和构建Java项目的工具. Maven的作用? 先来简单介绍一下Maven的作用 (1)依赖管理 方便快捷的管理项目依赖 ...

  5. salesforce零基础学习(一百一十六)workflow -> flow浅谈

    本篇参考: https://help.salesforce.com/s/articleView?id=sf.migrate_to_flow_tool_considerations_workflow.h ...

  6. 如何用浏览器读取本地文件(兼容IE8),new bing能帮我吗?

    浏览器读写文件? 有一份老旧而精巧的代码(2006或更早),带js的html,可以只用浏览器来处理一些二进制存档数据. 文件的读写怎么办?通过变动的方法来完成. 利用十六进制编辑软件如WinHEX,直 ...

  7. JS一切皆对象理解

    对象都是通过函数创建的 function Fn() { this.name = '王福朋'; this.year = 1988; } var fn1 = new Fn(); fn1是个对象,它是由函数 ...

  8. Linux文件系统故障,Input/output error

    事情是这样的,在启动某一个应用程序的时候,出现 Input/output error 的报错,磁盘以及目录无法使用的情况下,进行了重启,重启完成后是可以正常使用的,过一段时间后就会再次出现这个问题,一 ...

  9. HaProxy 安装搭建配置

    HaProxy简介 HAProxy是一个免费的负载均衡软件,可以运行于大部分主流的Linux操作系统上. HAProxy提供了L4(TCP)和L7(HTTP)两种负载均衡能力,具备丰富的功能.HAPr ...

  10. sms-activate操作简便易上手且好用的接码工具【保姆级教程】

    前言 有些国外应用在使用应用上的功能时需要注册账号,由于某种不可抗因素,我们的手机号一般不支持注册,接收不到信息验证码,于是我们可以使用SmS-Activate提供的服务,使用$实现我们的需求(大概一 ...