hdu4292网络流dinic
因为数组开小了,导致tle了一整天:(
tle的几点原因:http://blog.csdn.net/ameir_yang/article/details/53698478
思路都是对的,把每个人进行拆点,和dining那题差不多,加一个超级源一个超级汇
#include<map>
#include<set>
#include<cmath>
#include<queue>
#include<stack>
#include<vector>
#include<cstdio>
#include<cassert>
#include<iomanip>
#include<cstdlib>
#include<cstring>
#include<iostream>
#include<algorithm>
#define pi acos(-1)
#define ll long long
#define mod 1000000007
#define ls l,m,rt<<1
#define rs m+1,r,rt<<1|1
#pragma comment(linker, "/STACK:1024000000,1024000000") using namespace std; const double g=10.0,eps=1e-;
const int N=+,maxn=,inf=; struct Node {
int to,next,cap;
}e[maxn];
int s,t,cnt,dis[N];
int head[N];
void add(int u,int v,int c)
{
e[cnt].to=v;
e[cnt].cap=c;
e[cnt].next=head[u];
head[u]=cnt++;
e[cnt].to=u;
e[cnt].cap=;
e[cnt].next=head[v];
head[v]=cnt++;
}
bool bfs()
{
memset(dis,-,sizeof dis);
dis[s]=;
queue<int>q;
q.push(s);
while(!q.empty()){
int x=q.front();
q.pop();
for(int i=head[x];i!=-;i=e[i].next)
{
int temp=e[i].to;
if(dis[temp]==-&&e[i].cap>)
{
dis[temp]=dis[x]+;
q.push(temp);
}
}
}
return dis[t]!=-;
}
int dfs(int x,int mx)//a是找到的增广路上最小的流量
{
if(x==t)return mx;
int flow=;
for(int i=head[x];i!=-;i=e[i].next)
{
int temp=e[i].to,f;
if(dis[temp]==dis[x]+&&e[i].cap>&&(f=dfs(temp,min(mx,e[i].cap))))
{
e[i].cap-=f;
e[i^].cap+=f;
return f;
}
}
dis[x]=-;
return ;
}
int max_flow()
{
int ans=,f;
while(bfs()){
while((f=dfs(s,inf)))ans+=f;
}
return ans;
}
int main()
{
/* ios::sync_with_stdio(false);
cin.tie(0);*/
int n,f,d,a;
char op;
while(~scanf("%d%d%d",&n,&f,&d)){
cnt=;
memset(head,-,sizeof head);
s=,t=f+d+*n+;
for(int i=;i<=f;i++)
{
scanf("%d",&a);
add(,i,a);
}
for(int i=;i<=d;i++)
{
scanf("%d",&a);
add(f+*n+i,f+*n+d+,a);
}
for(int i=;i<=n;i++)
{
getchar();
for(int j=;j<=f;j++)
{
scanf("%c",&op);
if(op=='Y')add(j,f+i,);
}
}
for(int i=;i<=n;i++)
{
getchar();
add(f+i,f+i+n,);
for(int j=;j<=d;j++)
{
scanf("%c",&op);
if(op=='Y')add(f+n+i,f+*n+j,);
}
}
int ans=max_flow();
printf("%d\n",ans);
}
return ;
}
顺便把dining的dinic写法加上来
#include<map>
#include<set>
#include<cmath>
#include<queue>
#include<stack>
#include<vector>
#include<cstdio>
#include<cassert>
#include<iomanip>
#include<cstdlib>
#include<cstring>
#include<iostream>
#include<algorithm>
#define pi acos(-1)
#define ll long long
#define mod 1000000007
#define ls l,m,rt<<1
#define rs m+1,r,rt<<1|1
#pragma comment(linker, "/STACK:1024000000,1024000000") using namespace std; const double g=10.0,eps=1e-;
const int N=+,maxn=,inf=; struct Node {
int to,next,cap;
}e[N*];
int s,t,cnt,dis[N<<];
int head[N<<];
void add(int u,int v,int c)
{
e[cnt].to=v;
e[cnt].cap=c;
e[cnt].next=head[u];
head[u]=cnt++;
e[cnt].to=u;
e[cnt].cap=;
e[cnt].next=head[v];
head[v]=cnt++;
}
bool bfs()
{
memset(dis,-,sizeof dis);
dis[s]=;
queue<int>q;
q.push(s);
while(!q.empty()){
int x=q.front();
q.pop();
for(int i=head[x];i!=-;i=e[i].next)
{
int temp=e[i].to;
if(dis[temp]==-&&e[i].cap>)
{
dis[temp]=dis[x]+;
q.push(temp);
}
}
}
return dis[t]!=-;
}
int dfs(int x,int mx)//a是找到的增广路上最小的流量
{
if(x==t)return mx;
int flow=;
for(int i=head[x];i!=-;i=e[i].next)
{
int temp=e[i].to,f;
if(dis[temp]==dis[x]+&&e[i].cap>&&(f=dfs(temp,min(mx-flow,e[i].cap))))
{
e[i].cap-=f;
e[i^].cap+=f;
flow+=f;
}
}
if(!flow)dis[x]=-;
return flow;
}
int max_flow()
{
int ans=,f;
while(bfs()){
while((f=dfs(s,inf)))ans+=f;
}
return ans;
}
int main()
{
ios::sync_with_stdio(false);
cin.tie();
int n,f,d;
while(cin>>n>>f>>d){
cnt=;
memset(head,-,sizeof head);
for(int i=;i<=f;i++)add(,i,);
for(int i=;i<=d;i++)add(f+*n+i,f+*n+d+,);
for(int i=;i<=n;i++)
{
int a,b,k;
cin>>a>>b;
while(a--){
cin>>k;
add(k,f+i,);
}
while(b--){
cin>>k;
add(f+n+i,f+*n+k,);
}
}
for(int i=;i<=n;i++)add(f+i,f+i+n,);
s=,t=f+d+*n+;
int ans=max_flow();
cout<<ans<<endl;
}
return ;
}
hdu4292网络流dinic的更多相关文章
- POJ 1273 Drainage Ditches (网络流Dinic模板)
Description Every time it rains on Farmer John's fields, a pond forms over Bessie's favorite clover ...
- ACM/ICPC 之 有流量上下界的网络流-Dinic(可做模板)(POJ2396)
//有流量上下界的网络流 //Time:47Ms Memory:1788K #include<iostream> #include<cstring> #include<c ...
- 网络流Dinic(本篇介绍最大流)
前言:看到网上Dinic和ISAP的比较,多数人认为ISAP更快,不容易爆栈.当然,也有少数人认为,在多数情况下,Dinic比较稳定.我认为Dinic的思路比ISAP更简明,所以选择了Dinc算法 介 ...
- 模板——网络流Dinic
感谢这位大佬的博客:https://www.cnblogs.com/SYCstudio/p/7260613.html 给予了我莫大的帮助! 主要说一下网络流的几个注意点: 1.和二分图匹配相似,无法继 ...
- 最大网络流dinic
初始化flow(最大流量)为INF(极大值),建边(正向弧和反向弧) bfs寻找增广路看看有没有路,顺便进行深度标号.如果没有路直接结束输出flow. 如果有,我们按照深度dfs.dfs时注意在给正向 ...
- 网络流dinic实现总结
太羞耻了,搞了半天居然没发现自己写的不是dinic,直到被一道时限紧的题目卡掉才发现 int dfs(int now,int flow,int sum) { if(now==n) return flo ...
- poj 1459 Power Network : 最大网络流 dinic算法实现
点击打开链接 Power Network Time Limit: 2000MS Memory Limit: 32768K Total Submissions: 20903 Accepted: ...
- POJ 1273 Drainage Ditches(网络流dinic算法模板)
POJ 1273给出M条边,N个点,求源点1到汇点N的最大流量. 本文主要就是附上dinic的模板,供以后参考. #include <iostream> #include <stdi ...
- 高效的网络流dinic算法模版
#include <cstring> #include <algorithm> #include <vector> #define Maxn 120010 #def ...
随机推荐
- 一个不需要Log4Net的写日志的简单方法
有些项目写日志时会选择大名鼎鼎的Log4Net.而在我们使用它时,总会出现一些诸如版本不匹配而造成的写日志失败的情况,还要改web.config,还要改AssemblyInfo.而且,它的失败,并不是 ...
- zabbix debug and vulnerability https://www.zabbix.com/documentation/3.0/manual/concepts/sender
https://www.zabbix.com/documentation/3.0/manual/concepts/sender zabbix--- zabbix_sender -vv -z 172.2 ...
- form表单上传图片问题:线下可以而线上不可以
由于上传图片需要一定时间,而线下速度快线上速度慢. 所以如果你的上传窗口是弹出界面,那么就会面临上传未完成就关闭了该界面.导致上传失败.
- python之redis模块
一.redis简介 redis是一个key-value存储系统.和Memcached类似,它支持存储的value类型相对更多,包括string(字符串).list(链表).set(集合).zset(s ...
- HDU2426:Interesting Housing Problem(还没过,貌似入门题)
#include <iostream> #include <queue> #include <stdio.h> #include <string.h> ...
- 史上最全的MonkeyRunner自动化测试从入门到精通(3)
原文地址https://blog.csdn.net/liu_jing_hui/article/details/60956088 MonkeyRunner复杂的功能开始学习 (1)获取APK文件中ID的 ...
- Java String、StringBuffer、StringBuilder有什么区别
① String是Java语言非常基础和重要的类,提供了构造和管理字符串的各种基本逻辑.它是典型的immutable类,被声明成final class,所有属性也都是final的,由于它的不可变性,类 ...
- javascript 快速排序方法
"快速排序"的思想很简单,整个排序过程只需要三步: (1)在数据集之中,选择一个元素作为"基准"(pivot). (2)所有小于"基准"的元 ...
- Centos75 安装 postgresql11
切换到root账户, #安装yum 源 yum install https://download.postgresql.org/pub/repos/yum/11/redhat/rhel-7-x86_6 ...
- Vue学习笔记之表单绑定输入
vue的核心:声明式的指令和数据的双向绑定. 那么声明式的指令,已经给大家介绍完了.接下来我们来研究一下什么是数据的双向绑定? 另外,大家一定要知道vue的设计模式:MVVM M是Model的简写,V ...