题意:

农场主有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算法模板]的更多相关文章

  1. POJ 3281 网络流dinic算法

    B - Dining Time Limit:2000MS     Memory Limit:65536KB     64bit IO Format:%I64d & %I64u Submit S ...

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

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

  3. 网络流Dinic算法模板 POJ1273

    这就是以后我的板子啦~~~ #include <queue> #include <cstdio> #include <cstring> #include <a ...

  4. POJ 1815 - Friendship - [拆点最大流求最小点割集][暴力枚举求升序割点] - [Dinic算法模板 - 邻接矩阵型]

    妖怪题目,做到现在:2017/8/19 - 1:41…… 不过想想还是值得的,至少邻接矩阵型的Dinic算法模板get√ 题目链接:http://poj.org/problem?id=1815 Tim ...

  5. HDU1532最大流 Edmonds-Karp,Dinic算法 模板

    Drainage Ditches Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others) To ...

  6. hdu 2435 dinic算法模板+最小割性质

    #include<stdio.h> #include<queue> #include<string.h> using namespace std; #define ...

  7. POJ 1273 - Drainage Ditches - [最大流模板题] - [EK算法模板][Dinic算法模板 - 邻接表型]

    题目链接:http://poj.org/problem?id=1273 Time Limit: 1000MS Memory Limit: 10000K Description Every time i ...

  8. POJ 3469.Dual Core CPU 最大流dinic算法模板

    Dual Core CPU Time Limit: 15000MS   Memory Limit: 131072K Total Submissions: 24830   Accepted: 10756 ...

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

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

随机推荐

  1. Android接入支付宝和微信支付

    然后把下载下来的aar包,放到项目目录下面的libs目录下,通过下面的gradle依赖进来 // 支付宝 SDK AAR 包所需的配置compile(name: 'alipaySdk-15.6.0-2 ...

  2. ArrayList Vector LinkedList分析

    1.创建 ArrayList 的底层是一个数组.  ArrayList<String> list1 = new ArrayList<>(); list1.add("a ...

  3. BZOJ2120 数颜色(树套树)

    B. 数颜色 题目描述 墨墨购买了一套N支彩色画笔(其中有些颜色可能相同),摆成一排,你需要回答墨墨的提问.墨墨会像你发布如下指令:1. Q L R代表询问你从第L支画笔到第R支画笔中共有几种不同颜色 ...

  4. 安装Windows10+Ubentu18双系统

    1.先安装Windows系统,安装完成后,使用磁盘管理工具划分出一定的freespace空间留给linux安装系统用. 2.使用Universal-USB-Installer制作ubentu启动U盘. ...

  5. TP框架中同时使用“or”和“and”

    今天在tp中遇到一个问题,可能这并不算难的问题,但是我还是分享一下 以下是tp手册里面查询or的方式 $User = M("User"); // 实例化User对象 $where[ ...

  6. Memcached的安装和应用

    Memcached的安装 1.安装libeventlibevent是一个事件触发的网络库,适用于windows.linux.bsd等多种平台,内部使用 select.epoll.kqueue等系统调用 ...

  7. python 05 关于对python中引用的理解

    数据的在内存中的地址就是数据的引用. 如果两个变量为同一个引用,那么这两个变量对应的数据一定相同: 如果两个变量对应的数据相同,引用不一定相同. 通过id(数据)可以查看数据对应的地址,修改变量的值, ...

  8. Linux基础(Ubuntu)

    更换apt源为清华源 1.备份 /etc/apt/sources.list 2.vim 编辑 /etc/apt/sources.list 添加 deb http://mirrors.tuna.tsin ...

  9. selenium,phantomJS,python整合的一个小示例,把某个网页画面整体保存成图片格式。

    本篇将使用selenium,phantomJS和python制作的一个示例,把某个网页整体保存为一个图片文件. 简单介绍下,selenium是一个开源的用于测试web程序的工具,当然,如果你要执行一些 ...

  10. 最近的一些JAVA基础知识

    1,关于判断两个值是否相等 equal 和==是有区别到 2,判断一个数组集合 List是否为空 这个不能用"==null或者equal"要用isEmpty() , 对于不等于加一 ...