POJ 3281 [网络流dinic算法模板]
题意:
农场主有f种食物,d种饮料,n头牛。
接下来的n行每行第一个数代表第i头牛喜欢吃的食物数量,和第i头牛喜欢喝的饮料数目。
接下来分别是喜欢的食物和饮料的编号。
求解:农场主最多能保证几头牛同时能吃到喜欢的食物和喜欢的饮料。
思路:
从源点到每种食物加流量为1的边,保证每种食物只能被吃一次。
将每头牛分为两个点,连一条流量为1的边,保证每头牛最多只能吃一份食物喝一份饮料。
将每种饮料和汇点都进行连接,同样流量为1。
将牛喜欢的食物和牛进行连边流量为1,将另一组代表牛的点和喜欢的饮料进行连边,同样流量为1。
建好图之后就变成了最大流问题了。
这里留一个用dinic解决最大流问题的模板。
/*************************************************************************
> File Name: T.cpp
> Author: ttpond
> Created Time: 2015-8-22 12:4:42
************************************************************************/
#include<stdio.h>
#include<string.h>
#include<algorithm>
#include<iostream>
#include<math.h>
#include<vector>
#include<map>
#include<queue>
#include<stack>
#include<set>
using namespace std;
int z;
int n,f,d;
int pho[][];
int dis[];
int nb;
bool BFS()
{
nb++;
int i,j;
memset(dis,-,sizeof(dis));
int tmp;
queue<int>q;
dis[]=;
q.push();
while(!q.empty())
{
tmp=q.front();
q.pop();
for(int i=; i<=z; i++)
{
if(dis[i]<&&pho[tmp][i])
{
dis[i]=dis[tmp]+;
q.push(i);
}
}
}
if(dis[z]>)
return ;
else
return ;
}
int findans(int x,int low)
{
int i,a=;
if(x==z)
return low;
for(i=; i<=z; i++)
{
if(pho[x][i]>&&dis[i]==dis[x]+&&(a=findans(i,min(low,pho[x][i]))))
{
pho[x][i]-=a;
pho[i][x]+=a;
return a;
}
}
return ;
}
int main()
{
int a,b,tmp;
scanf("%d%d%d",&n,&f,&d);
z=+f+n*+d;
memset(pho,,sizeof(pho));
for(int i=; i<=+f; i++)
{
pho[][i]=;
}
for(int i=f+; i<=f+n+; i++)
{
pho[i][i+n]=;
}
for(int i=+f+n*; i<=+f+n*+d; i++)
{
pho[i][+f+n*+d]=;
}
for(int i=; i<=n; i++)
{
scanf("%d%d",&a,&b);
for(int j=; j<=a; j++)
{
scanf("%d",&tmp);
pho[tmp+][i+f+]=;
}
for(int j=; j<=b; j++)
{
scanf("%d",&tmp);
pho[i+f++n][tmp+f++n*]=;
}
}
int ans=,tans;
while(BFS())
{
while(tans=findans(,0x7fffffff))
{
ans+=tans;
}
}
printf("%d\n",ans);
}
POJ 3281 [网络流dinic算法模板]的更多相关文章
- POJ 3281 网络流dinic算法
B - Dining Time Limit:2000MS Memory Limit:65536KB 64bit IO Format:%I64d & %I64u Submit S ...
- POJ 1273 Drainage Ditches(网络流dinic算法模板)
POJ 1273给出M条边,N个点,求源点1到汇点N的最大流量. 本文主要就是附上dinic的模板,供以后参考. #include <iostream> #include <stdi ...
- 网络流Dinic算法模板 POJ1273
这就是以后我的板子啦~~~ #include <queue> #include <cstdio> #include <cstring> #include <a ...
- POJ 1815 - Friendship - [拆点最大流求最小点割集][暴力枚举求升序割点] - [Dinic算法模板 - 邻接矩阵型]
妖怪题目,做到现在:2017/8/19 - 1:41…… 不过想想还是值得的,至少邻接矩阵型的Dinic算法模板get√ 题目链接:http://poj.org/problem?id=1815 Tim ...
- HDU1532最大流 Edmonds-Karp,Dinic算法 模板
Drainage Ditches Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others) To ...
- hdu 2435 dinic算法模板+最小割性质
#include<stdio.h> #include<queue> #include<string.h> using namespace std; #define ...
- POJ 1273 - Drainage Ditches - [最大流模板题] - [EK算法模板][Dinic算法模板 - 邻接表型]
题目链接:http://poj.org/problem?id=1273 Time Limit: 1000MS Memory Limit: 10000K Description Every time i ...
- POJ 3469.Dual Core CPU 最大流dinic算法模板
Dual Core CPU Time Limit: 15000MS Memory Limit: 131072K Total Submissions: 24830 Accepted: 10756 ...
- poj 1459 Power Network : 最大网络流 dinic算法实现
点击打开链接 Power Network Time Limit: 2000MS Memory Limit: 32768K Total Submissions: 20903 Accepted: ...
随机推荐
- Debian9镜像安装问题
Debian9下载地址 https://www.debian.org/distrib/ Debian9有三个镜像文件 第一个包含系统2.3两个主要是一些软件的安装包只需下载第一个安装系统即可 默认安装 ...
- ubuntu破解密码方法
摘要: 开机按住任何键(shift)停住grub菜单,进入advanced option for ubuntu,出现的菜单中,光标移动至…(recovery mode)按E进入编辑,找到ro reco ...
- 简洁的KVO -- 使用Block响应事件
涉及内容: KVO,Runtime,Category,Block 首先创建NSObject的Category 举个例子是这样的: 随后定义你需要响应的Block结构 我简单一点就这样咯 typedef ...
- JavaFX Chart设置数值显示
一.XYChart import javafx.application.Application;import javafx.geometry.NodeOrientation;import javafx ...
- uva1612 Guess
和cf的打分有点像啊 因为一共只有三道题,所以每个人的得分最多有8种可能性.把这8种可能性都算出来,存在数组里,排好序备用排名就是一个天然的链表,给出了扫描的顺序扫描时,维护两个变量:前一个playe ...
- 目录下 shift 右键菜单 打开cmd 或者在 地址栏输入cmd 回车进入cmd
目录下 shift 右键菜单 打开cmd 或者在 地址栏输入cmd 回车进入cmd
- iview upload on-format-error 事件 在 before-upload 事件 之后,导致在before里面阻止上传后,监测事件失效,需要自己手工写
iview upload on-format-error 事件 在 before-upload 事件 之后,导致在before里面阻止上传后,监测事件失效,需要自己手工写
- linux部署全流程(未完)
一.环境搭建 1.jdk 2.tomcat 3.nginx 4.redis 推荐工具:winSCP(用来传输文件).SecureCRT(用来执行命令) 1.jdk 下载地址:https://www.o ...
- C-基础:C语言为什么不做数组下标越界检查
//这段代码运行有可能不报错.]; ;i<;i++) { a[i]=i; } 1.为了提高运行效率,不检查数组下表越界,程序就可以跑得快.因为C语言并不是一个快速开发语言,它要求开发人员保证所有 ...
- JavaSE-27 JDBC
学习要点 JDBC 查询数据 添加数据 修改数据 删除数据 JDBC 1 JDBC的定义 JDBC是Java数据库连接技术的简称,提供连接和操作各种常用数据库的能力. 2 JDBC工作原理 3 ...