碟战

时间限制:2000 ms  |  内存限制:65535 KB
难度:4
描述

知己知彼,百战不殆!在战争中如果被敌人掌握了自己的机密,失败是必然的。K国在一场战争中屡屡失败,就想到自己的某些城市可能会有敌方的间谍。

在仔细调查后,终于得知在哪些城市存在间谍。当然这个消息也被敌方间谍得知,所以间谍们开始撤离,试图到达K国唯一机场,然后抢夺飞机回国。由于城市内部比较复杂,K国领导人决定封锁道路,阻止所有间谍到达机场。城市编号为1~N,两个城市有不超过1条双向道路相连。机场在N号城市,不会有间碟。

由于要节约兵力,至少要封锁多少条道路才能阻止所有间谍到达机场?

输入
第一行包含一个整数T(T <= 100),为测试数据组数。
接下来每组测试数据第一行包含三个整数n,m,p(2<= n <= 200,1< m < 20000,1 <= p < n),分别表示城市数量,道路数量,存在间谍的城市的数量。
接下来的一行包含p个整数x(1 <= x < n),表示存在间谍城市的编号。
接下来的m行,每行包含两个整数i,j,表示城市i与城市j有道路相通。
输出
输出“Case #i: ans”(不含引号),i为第i组数据,ans为需要封锁道路的条数。
样例输入
2
4 4 2
1 2
1 2
2 4
1 3
3 4
4 3 2
1 2
2 3
3 4
2 4
样例输出
Case #1: 2
Case #2: 2

解题思路:简单的最大流最小割定理,设置一个超级源点,与所有有间谍的城市连一条边,容量为无穷大,表示不会去割这条边,然后其它边不变,容量为1,注意要连双向边,汇点为N号节点。

#include<iostream>
#include<cstdio>
#include<cstring>
#include<queue>
using namespace std;const int maxn = 1000;
const int INF = 0x3f3f3f3f;
struct Edge
{int to,next,flow;
}edge[160005];
int n,m,p;
int head[maxn],level[maxn],cnt;void addedge(int u,int v,int flow)
{  edge[cnt].to = v;  edge[cnt].flow = flow;  edge[cnt].next = head[u];  head[u] = cnt++;  swap(u,v);  edge[cnt].to = v;  edge[cnt].flow = 0;  edge[cnt].next = head[u];  head[u] = cnt++;
}  int BFS(int src,int des){  queue<int>q;  memset(level,0,sizeof(level));  level[src]=1;  q.push(src);  while(!q.empty()){  int u = q.front();  q.pop();  if(u==des) return 1;  for(int k = head[u];k!=-1;k=edge[k].next){  int v = edge[k].to,w=edge[k].flow;  if(level[v]==0&&w!=0){  level[v]=level[u]+1;  q.push(v);  }  }  }  return -1;
}  int dfs(int u,int des,int increaseRoad){  if(u==des) return increaseRoad;  int ret=0;  for(int k=head[u];k!=-1;k=edge[k].next){  int v = edge[k].to,w=edge[k].flow;  if(level[v]==level[u]+1&&w!=0){  int MIN = min(increaseRoad-ret,w);  w = dfs(v,des,MIN);  if(w > 0)  {  edge[k].flow -= w;  edge[k^1].flow += w;  ret+=w;  if(ret==increaseRoad) return ret;  }  else level[v] = -1;   }  }  return ret;
}  int Dinic(int src,int des){  int ans = 0;  while(BFS(src,des)!=-1) ans+=dfs(src,des,INF);  return ans;
}  int main()
{int t,u,v,cas = 1;scanf("%d",&t);while(t--){cnt = 0;memset(head,-1,sizeof(head));scanf("%d %d %d",&n,&m,&p);for(int i = 1; i <= p; i++){scanf("%d",&u);addedge(0,u,INF);}for(int i = 1; i <= m; i++){scanf("%d %d",&u,&v);addedge(u,v,1);addedge(v,u,1);}printf("Case #%d: %d\n",cas++,Dinic(0,n));}return 0;
}

nyoj 677 碟战(最大流最小割定理)相关推荐

  1. hihocoder 网络流二·最大流最小割定理

    网络流二·最大流最小割定理 时间限制:10000ms 单点时限:1000ms 内存限制:256MB 描述 小Hi:在上一周的Hiho一下中我们初步讲解了网络流的概念以及常规解法,小Ho你还记得内容么? ...

  2. 最大流最小割定理(max flow/min cut theory)

    百度文库里面有个地址,讲的比较详细. http://wenku.baidu.com/link?url=gPXhYCduLNgZaOkKIltNDAgPGwuMTpRX7a0utvVFuqDAP9o1j ...

  3. GraphCut、最大流最小割定理

    G=(V,E):V为点集,E为边集: 节点集V中的节点分为: (1)终端节点.不包含图像像素,用S和T表示.S为源点,T为汇点.图像分割中通常用S表示前景目标,标签设为1:T表示背景,标签为0. (2 ...

  4. 流网络的最小割问题c语言,网络流基础-最大流最小割定理

    最大流最小割定理,指网络流的最大流等于其最小割. 最大流指符合三个性质的前提下,从S到T能流过的最大流量. 最小割指符合割的定义,最小的割容量. 求最大流: 不断寻找增广路,计算能增加的最小流量,然后 ...

  5. Cable TV Network POJ - 1966 最大流最小割定理 点边转化

    最大流最小割定理 任何一个网络的最大流量等于最小割中边的容量之和 即最大流等于最小割 点边转化 节点可以拆为入点和出点 把点的属性添加到入点和出点之间的边上 图的边也可以分两截 在中间加一个节点 把边 ...

  6. UVA-10480 Sabotage(最大流最小割定理+输出路径)

    题目链接:UVA-10480 Sabotage The regime of a small but wealthy dictatorship has been abruptly overthrown ...

  7. 网络流(二)——最大流最小割定理

    最小割 <1>什么是割?     引例:你的仇人是一个工厂老板.你要炸掉一些车,让他每个货物都运不到销售点.         炸掉越大的车,你越容易被发现.你希望炸掉的车的容量之和尽量小. ...

  8. 8.10 最大流最小割定理

    文章目录 基本概念 定理:流小于等于割容量 Max-Flow Min-Cut Theorem 基本概念   网络流Network Flow,是用来研究现实生活中的水.电.油.气.交通.互联网等网络结构 ...

  9. hihoCoder 1378 网络流二·最大流最小割定理 (网络流学习#2 记录)

    题目链接:http://hihocoder.com/problemset/problem/1378 代码: #include<bits/stdc++.h> using namespace ...

最新文章

  1. java xml中的冒号_Java jdom解析xml文件带冒号的属性
  2. sql 计算两个小数乘积_数学家是如何计算出π的?
  3. Spring Boot 2 实践记录之 条件装配
  4. Python模块——_winreg操作注册表
  5. 辞旧迎新:2018年的分区你们建了吗?
  6. java spark on hive_hive-on-spark 安装 以及 scala 实例
  7. IOS推送消息怎么实现icon图标的数字累加
  8. qwt的安装和移植-
  9. 数据库索引键uk_数据库SQLServer
  10. os.environ 和 keras.json
  11. vue2.0一起在懵逼的海洋里越陷越深(二)
  12. jquery is 用于查看选择的元素是否匹配选择器。
  13. 第五章平稳过程(1)
  14. 英语四六级听力调频广播电台方案
  15. Lenovo System X3850 X5 服务器管理口IMM被锁定无法登录的故障处理
  16. vue3 setup vetur报错 解决方案 vscode
  17. pxe自动装机利用tfp,http,nfs服务实现。
  18. VC中鼠标移动点击操作
  19. 运营商-银联-手机厂商,三巨头如何依次主导NFC
  20. linux shell 进程监控脚本,shell脚本监控进程

热门文章

  1. XML数据读取——Digester简单使用
  2. 深入分析 Flutter 初始化流程
  3. Netronome为中国云计算大幅提速升效降成本
  4. PHP 自学教程之MySQL数据库
  5. 《NX-OS与Cisco Nexus交换技术:下一代数据中心架构(第2版)》一1.5 VDC
  6. 【小技巧】Xcode7.1中KSImageNamed无效的解决方法
  7. JavaScript对象的创建之动态原型方式
  8. Lamp的搭建--centos6.5下安装mysql
  9. 划分VLAN将生成树协议中的阻塞端口设置为转发端口
  10. 数学笔记--线性代数