因为数组开小了,导致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的更多相关文章

  1. POJ 1273 Drainage Ditches (网络流Dinic模板)

    Description Every time it rains on Farmer John's fields, a pond forms over Bessie's favorite clover ...

  2. ACM/ICPC 之 有流量上下界的网络流-Dinic(可做模板)(POJ2396)

    //有流量上下界的网络流 //Time:47Ms Memory:1788K #include<iostream> #include<cstring> #include<c ...

  3. 网络流Dinic(本篇介绍最大流)

    前言:看到网上Dinic和ISAP的比较,多数人认为ISAP更快,不容易爆栈.当然,也有少数人认为,在多数情况下,Dinic比较稳定.我认为Dinic的思路比ISAP更简明,所以选择了Dinc算法 介 ...

  4. 模板——网络流Dinic

    感谢这位大佬的博客:https://www.cnblogs.com/SYCstudio/p/7260613.html 给予了我莫大的帮助! 主要说一下网络流的几个注意点: 1.和二分图匹配相似,无法继 ...

  5. 最大网络流dinic

    初始化flow(最大流量)为INF(极大值),建边(正向弧和反向弧) bfs寻找增广路看看有没有路,顺便进行深度标号.如果没有路直接结束输出flow. 如果有,我们按照深度dfs.dfs时注意在给正向 ...

  6. 网络流dinic实现总结

    太羞耻了,搞了半天居然没发现自己写的不是dinic,直到被一道时限紧的题目卡掉才发现 int dfs(int now,int flow,int sum) { if(now==n) return flo ...

  7. poj 1459 Power Network : 最大网络流 dinic算法实现

    点击打开链接 Power Network Time Limit: 2000MS   Memory Limit: 32768K Total Submissions: 20903   Accepted:  ...

  8. POJ 1273 Drainage Ditches(网络流dinic算法模板)

    POJ 1273给出M条边,N个点,求源点1到汇点N的最大流量. 本文主要就是附上dinic的模板,供以后参考. #include <iostream> #include <stdi ...

  9. 高效的网络流dinic算法模版

    #include <cstring> #include <algorithm> #include <vector> #define Maxn 120010 #def ...

随机推荐

  1. HRBUST - 1153 意外 HRBUST - 1153 (数论)

    意外 Time Limit: 1000 MS Memory Limit: 65536 K Total Submit: 326(87 users) Total Accepted: 97(63 users ...

  2. dongle --NFC

    A dongle is a small piece of hardware that attaches to a computer, TV, or other electronic device in ...

  3. Python的Flask框架应用调用Redis队列数据的方法

    转自:http://www.jb51.net/article/86021.htm 任务异步化 打开浏览器,输入地址,按下回车,打开了页面.于是一个HTTP请求(request)就由客户端发送到服务器, ...

  4. Linux学习 -->解决Ubuntu系统上 No command 'crond' found

    前两天,准备在Ubuntu服务器上,定时执行Gitlab备份的命令,如下所示 编辑 vi /etc/crontab 文件,添加如下定时脚本 # edited by ouyang 2017-8-11 添 ...

  5. tobii SDK开发学习

    最近实验室用到tobii的眼动仪,从网上了解了下,tobii是瑞典的眼跟踪技术开发商,今年似乎有上市计划,不知道市值多少 买了仪器后试用了下,还算可以,将来配合人体设备开发,不过配套软件还需要花钱买. ...

  6. Mybatis 创建Configuration对象

    Mybatis  创建Configuration对象是在项目启动时就创建了. 具体创建流程为: https://blog.csdn.net/wolfcode_cn/article/details/80 ...

  7. PAT 1046 Shortest Distance[环形][比较]

    1046 Shortest Distance(20 分) The task is really simple: given N exits on a highway which forms a sim ...

  8. C语言——stdio.h

        int fgetc(FILE * stream); get character from stream 返回流中的一个字符,并以int的类型返回,如果碰到文件的结尾,或者一个错误发生,函数返回 ...

  9. SpringData修改和删除操作

    SpringData的查询我们已经学完了,我们现在就研究一下SpringData的修改和删除. @Modifying 注解和事务 @Query 与 @Modifying 这两个 annotation一 ...

  10. (28)Cocos2d-x xml解析

    Cocos2d-x 已经加入了tinyxml2用于xml的解析.3.0版本位于external/tinyxml2下.2.x版本位于cocos2dx/support/tinyxml2下. tinyxml ...