传送门

简化题意

给你 \(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. 《程序员的自我修养》学习笔记——ELF 文件结构介绍【第二弹】

    ELF 文件结构介绍 文件头 以 ELF 文件64位版本为例: e_ident [ELF魔数 16byte] 1-4字节:ELF 文件都必须相同的标识码,分别为 0x7F,0x45,0x4C,0x46 ...

  2. 我用 Laf 三分钟写了一个专属 ChatGPT ,Laf 创始人:明天来上班!

    起因 故事是这样的,一个月黑风高的夜晚,我掏出手机像往常一样打开朋友圈. 一开始我是不相信的,直到我(快速的) --> 打开 laf --> 创建应用 --> 新建云函数 --> ...

  3. 百度生成式AI产品文心一言邀你体验AI创作新奇迹:百度CEO李彦宏详细透露三大产业将会带来机遇(文末附文心一言个人用户体验测试邀请码获取方法,亲测有效)

    目录 中国版ChatGPT上线发布 强大中文理解能力 智能文学创作.商业文案创作 图片.视频智能生成 中国生成式AI三大产业机会 新型云计算公司 行业模型精调公司 应用服务提供商 总结 获取文心一言邀 ...

  4. 基于VirutalBox搭建虚拟机间互通的可访问公网的mini主机群

    目标 在单台PC机上安装3+台虚拟机[1] 这些虚拟机间可以相互访问 宿主机[2]与虚拟机可以相互访问 虚拟机可以访问公网 本文将采用 NAT + Host-Only 双网卡的方式实现上述目标,因为采 ...

  5. IDEA配置JDK版本的地方, 适用于Compilation failed: internal java compiler error

    错误原因: 1. 编译版本不匹配 2.当前项目jdk版本不支持 解决方法 查看项目的jdk 查看工程的jdk 查看java编译器版本 讲这些改成自己需要的版本, 一般就可以解决编译版本出现的错误

  6. 003-Cruehead-CrackMeV3

    第二个需要写注册机 首先查看文件,打开文件,什么也没有,help ->about,弹出下面的弹窗 看来是没有什么线索,直接放进OD里面 这里有一个函数CreatFileA,这个函数目的是访问一个 ...

  7. sort和sorted区别----引子:多维列表,如何实现第一个元素升序,第二个元素降序

    一.列表内建方法--sort() 作用:就地对列表排序(直接在原列表上做排序) 语法: list.sort(func=None, key=None, reverse=False) 当reverse=F ...

  8. cephadm 安装部署 ceph 集群

    介绍 手册: https://access.redhat.com/documentation/zh-cn/red_hat_ceph_storage/5/html/architecture_guide/ ...

  9. kubernetes核心实战(八)--- service

    13.service 四层网络负载 创建 [root@k8s-master-node1 ~/yaml/test]# [root@k8s-master-node1 ~/yaml/test]# vim m ...

  10. [Linux]scp/sshpass:物理主机与虚拟机的文件传输

    最初写这篇文章的时候,对 openssh大家族的工具套件(例如: ssh.sshd.ssl.scp等)不太熟悉,现在看来这个文章的标题(虚拟机与物理机)是存在问题的. 本质上,本文关心的并不是[虚拟机 ...