P1344 [USACO4.4]追查坏牛奶Pollutant Control

题目描述

你第一天接手三鹿牛奶公司就发生了一件倒霉的事情:公司不小心发送了一批有三聚氰胺的牛奶。很不幸,你发现这件事的时候,有三聚氰胺的牛奶已经进入了送货网。这个送货网很大,而且关系复杂。你知道这批牛奶要发给哪个零售商,但是要把这批牛奶送到他手中有许多种途径。送货网由一些仓库和运输卡车组成,每辆卡车都在各自固定的两个仓库之间单向运输牛奶。在追查这些有三聚氰胺的牛奶的时候,有必要保证它不被送到零售商手里,所以必须使某些运输卡车停止运输,但是停止每辆卡车都会有一定的经济损失。你的任务是,在保证坏牛奶不送到零售商的前提下,制定出停止卡车运输的方案,使损失最小。

输入输出格式

输入格式:

第一行: 两个整数\(N(2<=N<=32)\)、\(M(0<=M<=1000)\), \(N\)表示仓库的数目,\(M\)表示运输卡车的数量。仓库1代 表发货工厂,仓库\(N\)代表有三聚氰胺的牛奶要发往的零售商。 第\(2..M+1\)行: 每行3个整数\(S_i,E_i,C_i\)。其中\(S_i,E_i\)表示这 辆卡车的出发仓库,目的仓库。\(C_i(0 <= C_i <= 2,000,000)\) 表示让这辆卡车停止运输的损失。

输出格式:

两个整数\(C\)、\(T\):\(C\)表示最小的损失,\(T\)表示在损失最小的前提下,最少要停止的卡车数。


第一问很显然直接连上权值有向边直接最小割了。

第二问需要统计最小的割边数量。

我们先把第一问断开的边权置1,表示可以取,然后把其他的正向边置\(inf\),表示不能取,反向边仍然置0。再次跑最小割。

这时候最小割割去最少的边使图分成了两半,置\(inf\)使不合法的边不会被割去。


Code:

  1. #include <cstdio>
  2. #include <queue>
  3. #include <cstring>
  4. using namespace std;
  5. const int N=35;
  6. const int M=1010;
  7. const int inf=0x3f3f3f3f;
  8. int head[N],Next[M<<1],to[M<<1],edge[M<<1],cnt=1;
  9. void add(int u,int v,int w)
  10. {
  11. Next[++cnt]=head[u];to[cnt]=v;edge[cnt]=w;head[u]=cnt;
  12. Next[++cnt]=head[v];to[cnt]=u;edge[cnt]=0;head[v]=cnt;
  13. }
  14. int dep[N],n,m;
  15. bool bfs()
  16. {
  17. queue <int > q;
  18. q.push(1);
  19. memset(dep,0,sizeof(dep));
  20. dep[1]=1;
  21. while(!q.empty())
  22. {
  23. int u=q.front();
  24. q.pop();
  25. for(int i=head[u];i;i=Next[i])
  26. {
  27. int v=to[i];
  28. if(!dep[v]&&edge[i])
  29. {
  30. dep[v]=dep[u]+1;
  31. q.push(v);
  32. if(v==n) return 1;
  33. }
  34. }
  35. }
  36. return 0;
  37. }
  38. int dfs(int now,int flow)
  39. {
  40. if(now==n) return flow;
  41. int rest=flow,k;
  42. for(int i=head[now];i;i=Next[i])
  43. {
  44. int v=to[i];
  45. if(edge[i]&&dep[v]==dep[now]+1)
  46. {
  47. k=dfs(v,min(edge[i],rest));
  48. if(!k) dep[v]=0;
  49. rest-=k;
  50. edge[i]-=k;
  51. edge[i^1]+=k;
  52. }
  53. }
  54. return flow-rest;
  55. }
  56. void init()
  57. {
  58. scanf("%d%d",&n,&m);
  59. int u,v,w;
  60. for(int i=1;i<=m;i++)
  61. {
  62. scanf("%d%d%d",&u,&v,&w);
  63. add(u,v,w);
  64. }
  65. }
  66. int dinic()
  67. {
  68. int maxflow=0,flow;
  69. while(bfs())
  70. while(flow=dfs(1,inf)) maxflow+=flow;
  71. return maxflow;
  72. }
  73. void work()
  74. {
  75. printf("%d ",dinic());
  76. for(int i=2;i<=cnt;i+=2)
  77. {
  78. if(!edge[i])
  79. edge[i]=1;
  80. else
  81. edge[i]=inf;
  82. edge[i+1]=0;
  83. }
  84. printf("%d\n",dinic());
  85. }
  86. int main()
  87. {
  88. init();
  89. work();
  90. return 0;
  91. }

2018.7.1

洛谷 P1344 [USACO4.4]追查坏牛奶Pollutant Control 解题报告的更多相关文章

  1. 洛谷 P1344 [USACO4.4]追查坏牛奶Pollutant Control

    题目描述 你第一天接手三鹿牛奶公司就发生了一件倒霉的事情:公司不小心发送了一批有三聚氰胺的牛奶.很不幸,你发现这件事的时候,有三聚氰胺的牛奶已经进入了送货网.这个送货网很大,而且关系复杂.你知道这批牛 ...

  2. 洛谷 1344 [USACO4.4]追查坏牛奶Pollutant Control——最大流

    题目:https://www.luogu.org/problemnew/show/P1344 那个边数的限制,只要把边权乘1001再+1即可.乘1001是因为有1000条边,这样流量小的不会因为边数多 ...

  3. 【题解】Luogu P1344 [USACO4.4]追查坏牛奶Pollutant Control

    原题传送门 看到这种题,应该一眼就能知道考的是最小割 没错这题就是如此简单,跑两遍最大流(最小割=最大流),一次边权为题目所给,一次边权为1 还有一种优化,优化后只需跑一次最大流,把每条边的权值改成w ...

  4. luogu P1344 [USACO4.4]追查坏牛奶Pollutant Control

    传送门 要求断掉某些边使得两个点不连通,显然是最小割 但是要求选的边数尽量少,,, 可以考虑修改边权(容量),即把边权\(c\)改成\(c*(m+1)+1\) 没了 // luogu-judger-e ...

  5. [USACO4.4]追查坏牛奶Pollutant Control

    题目链接:ヾ(≧∇≦*)ゝ Solution: 第一问很好解决,根据网络流:最大流=最小割定理,我们可以轻松求出. 至于第二问,我们不妨把每一条边乘上一个大于1000的数再加上1. 这样的话,对于最小 ...

  6. 洛谷 P2751 [USACO4.2]工序安排Job Processing 解题报告

    P2751 [USACO4.2]工序安排Job Processing 题目描述 一家工厂的流水线正在生产一种产品,这需要两种操作:操作A和操作B.每个操作只有一些机器能够完成. 上图显示了按照下述方式 ...

  7. USACO Section 4.4 追查坏牛奶Pollutant Control

    http://www.luogu.org/problem/show?pid=1344 题目描述 你第一天接手三鹿牛奶公司就发生了一件倒霉的事情:公司不小心发送了一批有三聚氰胺的牛奶.很不幸,你发现这件 ...

  8. 洛谷 P1291 [SHOI2002]百事世界杯之旅 解题报告

    P1291 [SHOI2002]百事世界杯之旅 题目描述 "--在2002年6月之前购买的百事任何饮料的瓶盖上都会有一个百事球星的名字.只要凑齐所有百事球星的名字,就可参加百事世界杯之旅的抽 ...

  9. 洛谷 P1344 追查坏牛奶Pollutant Control —— 最小割

    题目:https://www.luogu.org/problemnew/show/P1344 就是求最小割: 但是还要边数最小,所以把边权都*1001+1,这样原来流量部分是*1001,最大流一样的不 ...

随机推荐

  1. 创世纪 BZOJ3037 & [Poi2004]SZP BZOJ2068

    分析: 树形DP中的一种,基环树DP 针对每一个环跑DP,f[i],g[i]分别表示选或者不选,之后我们注意每次遍历的时候,不要重复遍历. 附上代码: #include <cstdio> ...

  2. Java基础—常用类之String类

    一.String类是什么 public final class String implements java.io.Serializable, Comparable<String>, Ch ...

  3. 【转】从Shell脚本内部将所有标准输出及标准错误显示在屏幕并同时写入文件的方法

    如果全部都要重定向的话每一条命令后面>>并不方便,可以这么做.在开头就声明 exec 1>>$log_file表示将脚本中所有的正确输出全部追加到$log_file,错误信息会 ...

  4. Linux日记Day3---Linux的文件属性与目录配置

    Linux最优秀的地方之一,就在于它的多用户.多任务环境.为了让用户具有较安全的管理机制,文件的权限管理是很重要的.Linux通常将文件的访问方式分为分为三个类别,分别是owner/group/oth ...

  5. 校内模拟赛 coin

    题意: n*m的棋盘,每个格子可能是反着的硬币,正着的硬币,没有硬币,每次可以选未选择的一行或者未选择的一列,将这一行/列的硬币取反.如果没有可选的或者硬币已经全部正面,那么游戏结束. 最后一次操作的 ...

  6. 测试leader职责

    一. 负责软件产品/项目测试工作的组织 参加软件产品开发前的需求调研和分析 根据需求规格说明书,概要设计和开发计划编写项目总体测试计划,详细测试计划,测试大纲和测试文档结构表[测试计划 a.已上线产品 ...

  7. 调用wx.request接口时需要注意的几个问题

    写在前面 之前写了一篇<微信小程序实现各种特效实例>,上次的小程序的项目我负责大部分前端后台接口的对接,然后学长帮我改了一些问题.总的来说,收获了不少吧! 现在项目已经完成,还是要陆陆续续 ...

  8. stl源码剖析 详细学习笔记 算法(5)

    //---------------------------15/04/01---------------------------- //inplace_merge(要求有序) template< ...

  9. wireshark找不到网卡

    在Capture Opinions中的interface若找不到网卡,一般是npf服务没有启动. npf是什么东东 Netgroup Packet Filter 网络数据包过滤器 NPF Device ...

  10. 结对编程--C语言子程序词法分析

    一.问题描述 C语言小子集表的定义 2.设计单词属性值,各类表格(表示标识符表.常量表),单词符号及机内表示,采用标准输入和输出的方式.程序从键盘接收代码,遇到代码结束符"#"时结 ...