博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
UVALive 6887 Book Club
阅读量:7136 次
发布时间:2019-06-28

本文共 1646 字,大约阅读时间需要 5 分钟。

最大流,有向环覆盖问题。

#include
#include
#include
#include
#include
#include
#include
using namespace std;const int maxn = 100000 + 10;const int INF = 0x7FFFFFFF;struct Edge{ int from, to, cap, flow; Edge(int u, int v, int c, int f) :from(u), to(v), cap(c), flow(f){}};vector
edges;vector
G[maxn];bool vis[maxn];int d[maxn];int cur[maxn];int n, m, s, t;void init(){ for (int i = 0; i < maxn; i++) G[i].clear(); edges.clear();}void AddEdge(int from, int to, int cap){ edges.push_back(Edge(from, to, cap, 0)); edges.push_back(Edge(to, from, 0, 0)); int w = edges.size(); G[from].push_back(w - 2); G[to].push_back(w - 1);}bool BFS(){ memset(vis, 0, sizeof(vis)); queue
Q; Q.push(s); d[s] = 0; vis[s] = 1; while (!Q.empty()) { int x = Q.front(); Q.pop(); for (int i = 0; i
e.flow) { vis[e.to] = 1; d[e.to] = d[x] + 1; Q.push(e.to); } } } return vis[t];}int DFS(int x, int a){ if (x == t || a == 0) return a; int flow = 0, f; for (int &i = cur[x]; i
0) { edges[G[x][i]].flow+=f; edges[G[x][i] ^ 1].flow-=f; flow+=f; a-=f; if(a==0) break; } } if(!flow) d[x] = -1; return flow;}int dinic(int s, int t){ int flow = 0; while (BFS()) { memset(cur, 0, sizeof(cur)); flow += DFS(s, INF); } return flow;}int main(){ while(~scanf("%d%d",&n,&m)){ init(); s=0;t=2*n+1; for(int i=1;i<=n;i++) AddEdge(s,i,1); for(int i=n+1;i<=2*n;i++) AddEdge(i,t,1); for(int i=1;i<=m;i++) { int u,v; scanf("%d%d",&u,&v); u++; v++; AddEdge(u,v+n,1); } if(dinic(s,t)==n) printf("YES\n"); else printf("NO\n"); } return 0;}

 

转载于:https://www.cnblogs.com/zufezzt/p/4847047.html

你可能感兴趣的文章
Dubbo 是一个分布式服务框架
查看>>
js数组排序实用方法集锦
查看>>
calculate the time of methods
查看>>
python与正则表达式
查看>>
删除多个附件
查看>>
目标检测之显著区域检测---国外的一个图像显著区域检测代码及其效果图 saliency region detection...
查看>>
Laravel之路——事务
查看>>
WCF分布式开发步步为赢(10):请求应答(Request-Reply)、单向操作(One-Way)、回调操作(Call Back)....
查看>>
python的struct模块
查看>>
python进程和线程中的两个锁
查看>>
Java嵌入式数据库H2学习总结(二)——在Web应用程序中使用H2数据库
查看>>
(最小生成树 次小生成树)The Unique MST -- POJ -- 1679
查看>>
括号匹配(二) -- 经典动态规划
查看>>
在jsp中的css
查看>>
Issue 3:数据处理基本认识
查看>>
bat 每天开机自动从git/svn服务器更新代码
查看>>
腾讯开源的轻量级CSS3动画库:JX.Animate
查看>>
在android studio中配置运行时签名
查看>>
Java中动态代理实现原理深究
查看>>
URI和URL
查看>>