题目

皮卡丘被火箭队用邪恶的计谋抢走了!这三个坏家伙还给小智留下了赤果果的挑衅!为了皮卡丘,也为了正义,小智和他的朋友们义不容辞的踏上了营救皮卡丘的道路。

火箭队一共有N个据点,据点之间存在M条双向道路。据点分别从1到N标号。小智一行K人从真新镇出发,营救被困在N号据点的皮卡丘。为了方便起见,我们将真新镇视为0号据点,一开始K个人都在0号点。

由于火箭队的重重布防,要想摧毁K号据点,必须按照顺序先摧毁1到K-1号据点,并且,如果K-1号据点没有被摧毁,由于防御的连锁性,小智一行任何一个人进入据点K,都会被发现,并产生严重后果。因此,在K-1号据点被摧毁之前,任何人是不能够经过K号据点的。

为了简化问题,我们忽略战斗环节,小智一行任何一个人经过K号据点即认为K号据点被摧毁。被摧毁的据点依然是可以被经过的。

K个人是可以分头行动的,只要有任何一个人在K-1号据点被摧毁之后,经过K号据点,K号据点就被摧毁了。显然的,只要N号据点被摧毁,皮卡丘就得救了。

野外的道路是不安全的,因此小智一行希望在摧毁N号据点救出皮卡丘的同时,使得K个人所经过的道路的长度总和最少。

请你帮助小智设计一个最佳的营救方案吧!

输入格式

第一行包含三个正整数N,M,K。表示一共有N+1个据点,分别从0到N编号,以及M条无向边。一开始小智一行共K个人均位于0号点。

接下来M行,每行三个非负整数,第i行的整数为Ai,Bi,Li。表示存在一条从Ai号据点到Bi号据点的长度为Li的道路。

输出格式

仅包含一个整数S,为营救皮卡丘所需要经过的最小的道路总和。

输入样例

3 4 2

0 1 1

1 2 1

2 3 100

0 3 1

输出样例

3

【样例说明】

小智和小霞一起前去营救皮卡丘。在最优方案中,小智先从真新镇前往1号点,接着前往2号据点。当小智成功摧毁2号据点之后,小霞从真新镇出发直接前往3号据点,救出皮卡丘。

提示

对于100%的数据满足N ≤ 150, M ≤ 20 000, 1 ≤ K ≤ 10, Li ≤ 10 000, 保证小智一行一定能够救出皮卡丘。至于为什么K ≤ 10,你可以认为最终在小智的号召下,小智,小霞,小刚,小建,小遥,小胜,小光,艾莉丝,天桐,还有去日本旅游的黑猫警长,一同前去大战火箭队。

题解

比较容易想到,每一次的移动,一定是为了到达一个未摧毁的点,也就是一个比当前点都大的点

所以每一次移动时,路径上点点都不会比终点大

由此,我们可以floyd预处理两点间最短路,但用以更新的k不能比i和j都大

这样我们重建了一张竞赛图,也是一张拓扑图

现在问题就转化成了:选尽量短的几条从0出发的路径,使所有点都被覆盖

就有转化为了最小费用可行流

具体怎么建图,就不说了【懒。】

  1. #include<iostream>
  2. #include<cmath>
  3. #include<queue>
  4. #include<cstdio>
  5. #include<cstring>
  6. #include<algorithm>
  7. #define LL long long int
  8. #define REP(i,n) for (int i = 1; i <= (n); i++)
  9. #define Redge(u) for (int k = h[u],to; k; k = ed[k].nxt)
  10. #define BUG(s,n) for (int i = 1; i <= (n); i++) cout<<s[i]<<' '; puts("");
  11. using namespace std;
  12. const int maxn = 310,maxm = 500005,INF = 1000000000;
  13. inline int read(){
  14. int out = 0,flag = 1; char c = getchar();
  15. while (c < 48 || c > 57) {if (c == '-') flag = -1; c = getchar();}
  16. while (c >= 48 && c <= 57) {out = (out << 3) + (out << 1) + c - '0'; c = getchar();}
  17. return out * flag;
  18. }
  19. int n,m,K,h[maxn],ne = 2,S,T,SS,TT;
  20. struct EDGE{int to,nxt,f,w;}ed[maxm];
  21. inline void build(int u,int v,int f,int w){
  22. ed[ne] = (EDGE){v,h[u],f,w}; h[u] = ne++;
  23. ed[ne] = (EDGE){u,h[v],0,-w}; h[v] = ne++;
  24. }
  25. int d[maxn],minf[maxn],p[maxn],inq[maxn];
  26. queue<int> q;
  27. int mincost(){
  28. int flow = 0,cost = 0;
  29. while (true){
  30. for (int i = 0; i <= TT; i++) d[i] = INF,inq[i] = 0;
  31. d[SS] = 0; minf[SS] = INF;
  32. q.push(SS);
  33. int u;
  34. while (!q.empty()){
  35. u = q.front(); q.pop();
  36. inq[u] = false;
  37. Redge(u) if (ed[k].f && d[to = ed[k].to] > d[u] + ed[k].w){
  38. d[to] = d[u] + ed[k].w; p[to] = k; minf[to] = min(minf[u],ed[k].f);
  39. if (!inq[to]) q.push(to),inq[to] = true;
  40. }
  41. }
  42. if (d[TT] == INF) break;
  43. flow += minf[TT];
  44. cost += minf[TT] * d[TT];
  45. u = TT;
  46. while (u != SS){
  47. ed[p[u]].f -= minf[T];
  48. ed[p[u] ^ 1].f += minf[T];
  49. u = ed[p[u] ^ 1].to;
  50. }
  51. }
  52. return cost;
  53. }
  54. int G[maxn][maxn];
  55. void floyd(){
  56. for (int k = 0; k < n; k++)
  57. for (int i = 0; i < n; i++)
  58. for (int j = 0; j < n; j++)
  59. if ((k <= i || k <= j) && G[i][j] > G[i][k] + G[k][j])
  60. G[i][j] = G[i][k] + G[k][j];
  61. }
  62. void init(){
  63. for (int i = 0; i < n; i++){
  64. build(SS,i + n,1,0);
  65. build(i,TT,1,0);
  66. build(i,i + n,INF,0);
  67. build(i + n,T,INF,0);
  68. }
  69. build(S,0,K,0);
  70. build(T,S,INF,0);
  71. for (int i = 0; i < n; i++)
  72. for (int j = i + 1; j < n; j++)
  73. build(i + n,j,INF,G[i][j]);
  74. }
  75. int main(){
  76. n = read(); m = read(); K = read(); n++;
  77. S = 2 * n; T = S + 1; SS = T + 1; TT = SS + 1;
  78. int a,b,w;
  79. for (int i = 0; i < n; i++)
  80. for (int j = 0; j < n; j++)
  81. if (i != j) G[i][j] = INF;
  82. while (m--){
  83. a = read(); b = read(); w = read();
  84. G[a][b] = G[b][a] = min(G[a][b],w);
  85. }
  86. floyd();
  87. init();
  88. printf("%d\n",mincost());
  89. return 0;
  90. }

BZOJ2324 [ZJOI2011]营救皮卡丘 【费用流】的更多相关文章

  1. bzoj2324 [ZJOI2011]营救皮卡丘 费用流

    [ZJOI2011]营救皮卡丘 Time Limit: 10 Sec  Memory Limit: 256 MBSubmit: 2653  Solved: 1101[Submit][Status][D ...

  2. BZOJ.2324.[ZJOI2011]营救皮卡丘(费用流 Floyd)

    BZOJ 洛谷 首先预处理出\(dis[i][j]\),表示从\(i\)到\(j\)的最短路.可以用\(Floyd\)处理. 注意\(i,j\)是没有大小关系限制的(\(i>j\)的\(dis[ ...

  3. 【BZOJ 2324】[ZJOI2011]营救皮卡丘 费用流

    本人实行诱骗拐卖(利用自然分层与实际意义),正解拼接补充(充分利用最大流限制(不浪费任何一个走出去的机会而不是不浪费任何一个已有的流)与问题转换) #include <cstdio> #i ...

  4. BZOJ2324: [ZJOI2011]营救皮卡丘

    2324: [ZJOI2011]营救皮卡丘 Time Limit: 10 Sec  Memory Limit: 256 MBSubmit: 1359  Solved: 522[Submit][Stat ...

  5. BZOJ2324 ZJOI2011营救皮卡丘(floyd+上下界费用流)

    虽然不一定每次都是由编号小的点向编号大的走,但一个人摧毁的顺序一定是从编号小的到编号大的.那么在摧毁据点x的过程中,其只能经过编号小于x的点.并且这样一定合法,因为可以控制其他人先去摧毁所经过的点.那 ...

  6. bzoj 2324 ZJOI 营救皮卡丘 费用流

    题的大概意思就是给定一个无向图,边有权值,现在你有k个人在0点,要求走到n点,且满足 1:人们可以分头行动,可以停在某一点不走了 2:当你走到x时,前x-1个点必须全部走过(不同的人走过也行,即分两路 ...

  7. 【BZOJ2324】[ZJOI2011]营救皮卡丘(网络流,费用流)

    [BZOJ2324][ZJOI2011]营救皮卡丘(网络流,费用流) 题面 BZOJ 洛谷 题解 如果考虑每个人走的路径,就会很麻烦. 转过来考虑每个人破坏的点集,这样子每个人可以得到一个上升的序列. ...

  8. 【BZOJ2324】[ZJOI2011]营救皮卡丘 有上下界费用流

    [BZOJ2324][ZJOI2011]营救皮卡丘 Description 皮卡丘被火箭队用邪恶的计谋抢走了!这三个坏家伙还给小智留下了赤果果的挑衅!为了皮卡丘,也为了正义,小智和他的朋友们义不容辞的 ...

  9. bzoj 2324 [ZJOI2011]营救皮卡丘(floyd,费用流)

    2324: [ZJOI2011]营救皮卡丘 Time Limit: 10 Sec  Memory Limit: 256 MBSubmit: 1777  Solved: 712[Submit][Stat ...

随机推荐

  1. Java删除开头和末尾字符串

    //扩展2个String方法 /* * 删除开头字符串 */ public static String trimstart(String inStr, String prefix) { if (inS ...

  2. java基础—this关键字

    一.this关键字

  3. NSXMLParser

    NSXMLParser的使用 2011-05-05 15:50:17|  分类: 解析|字号 订阅     NSXMLParser解析xml格式的数据 用法如下: 首先,NSXMLParser必须继续 ...

  4. 【Machine Learning is Fun!】1.The world’s easiest introduction to Machine Learning

    Bigger update: The content of this article is now available as a full-length video course that walks ...

  5. 转载:将画布(canvas)图像保存成本地图片的方法

    之前我曾介绍过如何将HTML5画布(canvas)内容转变成图片形式,方法十分简单.但后来我发现只将canvas内容转变成图片输出还不够,如何能将转变后的图片保存到本地呢? 其实,这个方法也是非常简单 ...

  6. HDU:5040-Instrusive

    Instrusive Time Limit: 3000/1500 MS (Java/Others) Memory Limit: 262144/262144 K (Java/Others) Proble ...

  7. holtek编程注意事项

    1.holtek单片机中断服务函数中函数调用里的参数不能传递地址,不然程序就会跑飞 2.holtek单片机尽量不要函数嵌套很多层,嵌套过多,会导致单片机复位

  8. 打造一款属于自己的web服务器——从简单开始

    距离开篇已经过了很久,期间完善了一下之前的版本,目前已经能够完好运行,基本上该有的功能都有了,此外将原来的测试程序改为示例项目,新项目只需按照示例项目结构实现controller和view即可,详情见 ...

  9. RHEL6.X设置163yum源

    目录 RHEL6.X设置163yum源 卸载系统的yum 检查是否已经卸载完成 下载yum以及相关包 安装yum相关rpm包 清除原有缓存,建立yum列表 本地yum源设置 挂载本地光盘 修改配置文件 ...

  10. 0016.Linux基础之常用基本命令讲解

    开启linux系统,开启xshell pwd:printing workding directory 打印当前目录 /:代表根目录 cd:change directory 改变目录 ls:list 查 ...