如何建图?

  最开始的问题就是,怎么表示一只牛有了食物和饮料呢?

  后来发现可以先将食物与牛匹配,牛再去和饮料匹配,实际上这就构成了三个层次。

  起点到食物层边的容量是1,食物层到奶牛层容量是1,奶牛层到饮料层容量是1,饮料层到终点容量是1。

  但是后来发现有一组hack数据:

  2 3 3

  3 3 1 2 3 1 2 3
  3 3 1 2 3 1 2 3

  我们发现一头奶牛居然吃了多个套餐,所以要解决这个只需要将自己与自己建立一条容量是1的边就行了。

  

#include <cstdio>
#include <cstring>
#include <stack>
using namespace std;
#define sc scanf
#define pt printf
#define maxe 40960
#define maxv 405
#define maxn 1000
#define mll long long
const int inf = 0x3f3f3f3f;
int mn(int a,int b) { return a<b?a:b; }
int s,t, N,F,D;
typedef struct ed{
int v,w,cap,flow;
} ed;
ed e[maxe];
int head[maxv],nxt[maxe],tot,dis[maxv];
void init()
{
tot = ;
memset(head,-,sizeof(head));
} void add(int u,int v,int cap,int flow)
{
e[tot].v=v;
e[tot].cap=cap;
e[tot].flow=flow;
nxt[tot]=head[u];
head[u]=tot++; e[tot].v=u;
e[tot].cap=flow;
e[tot].flow=;
nxt[tot]=head[v];
head[v]=tot++;
}
int dfs(int u,int exp)
{
if(exp==||u==t) return exp;
int i,v,flow=,tmp;
for(i=head[u];i!=-;i=nxt[i])
{
v=e[i].v;
//pt("u=%d,v=%d\n",u,v); if(dis[v]==dis[u]+)
{
tmp = dfs(v,mn(e[i].cap-e[i].flow,exp));
if(tmp==) continue;
// pt("u=%d,v=%d,tmp=%d\n",u,v,tmp);
e[i].flow += tmp;
e[i^].flow -= tmp; exp-=tmp;
flow+=tmp; if(exp==) break;
}
}
//pt("wt\n");
if(flow==) dis[u]=inf;
return flow;
}
stack<int> q;
int main()
{
freopen("in.txt","r",stdin);
while(~sc("%d%d%d",&N,&F,&D))
{
//pt("OK\n");
int i,j,ans=,u,v,tt,FF,DD;
init(); s=,t=+*N+F+D;
// pt("OK\n");
// F使用1-F N使用(F+1 - F+N)(F+1 + N - F+ 2*N) D使用 F+2*N+1 - F+2*N+D
for(i=;i<=F;++i) add(,i,,);
for(i=F+*N+;i<=F+*N+D;++i) add(i,t,,);
for(i=F+;i<=F+N;++i) add(i,i+N,,);
//pt("OK\n");
for(i=;i<=N;++i)
{
sc("%d%d",&FF,&DD);
for(j=;j<=FF;++j)
{
sc("%d",&tt);
add(tt,F+i,,);
}
for(j=;j<=DD;++j)
{
sc("%d",&tt);
add(F+N+i,F+*N+tt,,);
}
}
//pt("OK\n");
while()
{
//BFS建立层次图
memset(dis,inf,sizeof(dis));
dis[s]=;
while(!q.empty()) q.pop();
q.push(s);
while(!q.empty())
{ u=q.top(); q.pop();
for(i=head[u];i!=-;i=nxt[i])
{
if(e[i].cap - e[i].flow <= ) continue;
v = e[i].v; if(dis[u]+<dis[v])
{
dis[v] = dis[u] +;
//pt("BFS: u=%d,v=%d\n",u,v);
if(v==t) break;
q.push(v);
} }
}
if(dis[t]==inf) break;
//DFS进行增广
tt=dfs(,inf);
if(tt==) break;
else ans+=tt;
//pt("tt=%d\n",tt); }
pt("%d\n",ans);
}
return ;
}

POJ 3281

POJ 3281 网络流 拆点保证本身只匹配一对食物和饮料的更多相关文章

  1. poj 3281(网络流+拆点)

    题目链接:http://poj.org/problem?id=3281 思路:设一个超级源点和一个超级汇点,源点与食物相连,饮料与汇点相连,然后就是对牛进行拆点,一边喜欢的食物相连,一边与喜欢的饮料相 ...

  2. POJ 3281 网络流 拆点 Dining

    题意: 有F种食物和D种饮料,每头牛有各自喜欢的食物和饮料,而且每种食物或者饮料只能给一头牛. 求最多能有多少头牛能同时得到它喜欢的食物或者饮料. 分析: 把每个牛拆点,中间连一条容量为1的边,保证一 ...

  3. POJ 3281 网络流dinic算法

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

  4. POJ 3281 网络流

    题意: 思路: 网络流 重在建图- 建完了图 就一切都好说了 这道题 我的想法是 先把源点和所有的食品连上边 (容量为1) 再把食品和对应的奶牛连上边 (容量为1) 这个时候要拆点 因为每只奶牛只能才 ...

  5. ACM Computer Factory POJ - 3436 网络流拆点+路径还原

    http://poj.org/problem?id=3436 每台电脑有$p$个组成部分,有$n$个工厂加工电脑. 每个工厂对于进入工厂的半成品的每个组成部分都有要求,由$p$个数字描述,0代表这个部 ...

  6. POJ 3281 Dining (拆点)【最大流】

    <题目链接> 题目大意: 有N头牛,F种食物,D种饮料,每一头牛都有自己喜欢的食物和饮料,且每一种食物和饮料都只有一份,让你分配这些食物和饮料,问最多能使多少头牛同时获得自己喜欢的食物和饮 ...

  7. poj 3281 Dining 拆点 最大流

    题目链接 题意 有\(N\)头牛,\(F\)个食物和\(D\)个饮料.每头牛都有自己偏好的食物和饮料列表. 问该如何分配食物和饮料,使得尽量多的牛能够既获得自己喜欢的食物又获得自己喜欢的饮料. 建图 ...

  8. POJ 3281 [网络流dinic算法模板]

    题意: 农场主有f种食物,d种饮料,n头牛. 接下来的n行每行第一个数代表第i头牛喜欢吃的食物数量,和第i头牛喜欢喝的饮料数目. 接下来分别是喜欢的食物和饮料的编号. 求解:农场主最多能保证几头牛同时 ...

  9. B - Dining POJ - 3281 网络流

    Cows are such finicky eaters. Each cow has a preference for certain foods and drinks, and she will c ...

随机推荐

  1. [BZOJ1492] [NOI2007] 货币兑换Cash(cdq分治+斜率优化)

    [BZOJ1492] [NOI2007] 货币兑换Cash(cdq分治+斜率优化) 题面 分析 dp方程推导 显然,必然存在一种最优的买卖方案满足:每次买进操作使用完所有的人民币:每次卖出操作卖出所有 ...

  2. 谈一下你对 uWSGI 和 nginx 的理解??

    1.uWSGI 是一个 Web 服务器,它实现了 WSGI 协议.uwsgi.http 等协议.Nginx 中HttpUwsgiModule 的作用是与 uWSGI 服务器进行交换.WSGI 是一种 ...

  3. [环境搭建]-Web Api搭建到IIS服务器后PUT请求返回HTTP Error 405.0 - Method Not Allowed 解决方法 转摘:http://blog.csdn.net/qiujuer/article/details/23827531

    尝试使用微软的Web Api,他的确是一个很有意思的东西. 让我体会到了许多的方便,但是我发现部署到IIS服务器上去了后PUT和Delete请求将返回405. 原因是IIS的默认处理程序默认情况下只允 ...

  4. RequireJS 入门(二)

    简介 如今最常用的JavaScript库之一是RequireJS.最近我参与的每个项目,都用到了RequireJS,或者是我向它们推荐了增加RequireJS.在这篇文章中,我将描述RequireJS ...

  5. day01-html

    HTML概述: HTML: Hyper Text Markup Language 超文本标记语言 超文本: 比普通文本功能更加强大,可以添加各种样式 标记语言: 通过一组标签.来对内容进行描述. &l ...

  6. Express 2015 RC for Windows 10 安装

    支持的操作系统 Windows 10 Technical Preview 硬件要求 1.6 GHz 或更快的处理器 1 GB RAM(如果在虚拟机上运行,则为 1.5 GB) 4 GB 可用硬盘空间 ...

  7. Tensorflow学习笔记3:卷积神经网络实现手写字符识别

    # -*- coding:utf-8 -*- import tensorflow as tf from tensorflow.examples.tutorials.mnist import input ...

  8. 使用C#解析XMIND文件格式

    static void Main(string[] args) { var tempPath = @"c:\Temp"; if (Directory.Exists(tempPath ...

  9. SICP 习题解 第二章

    计算机程序的构造和解释习题解答 Structure and Interpretation os Computer Programs Exercises Answer 第二章 构造数据抽象 练习2.17 ...

  10. 关于python读写文件的r+方式的坑

    写脚本的时候需要将文件中的一行修改,我的修改逻辑是,用r+方式打开文件,然后将原文件数据读入一个数组,修改数组的对应元素,在seek(0),然后将数组write进文件 结果: 文件文件末尾总是多出一行 ...