如何建图?

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

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

  起点到食物层边的容量是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. python进阶之类的反射

    有应用场景的技术才是有灵魂的技术------>最近同时问我,在python中,给你一个函数或者类的字符串名称,你怎么得到该函数和类,以下结合源码记录我得到的方式: 1.给一个函数的字符串&quo ...

  2. js如何实现上拉加载更多...

    我们在项目中经常使用到下拉加载更多,之前要么是底部写加载按钮,要么是引入插件.今天终于有时间手写一个了,之前感觉挺麻烦,明白原理后,其实很简单... scrollTop:滚动视窗的高度距离window ...

  3. 15、前端知识点--MVVM

    MVVM模式的理解 MVVM模式里面,核心是数据. 各种前端框架,最核心的说就是保持了数据与视图的同步. 数据驱动思想:数据驱动视图. Vue不建议手动操作DOM. 以前是指令操作DOM,其实本质上底 ...

  4. spark复习笔记(6):数据倾斜

    一.数据倾斜 spark数据倾斜,map阶段对key进行重新划分.大量的数据在经过hash计算之后,进入到相同的分区中,zao

  5. oralce 汇编02

    Assembler Directives .align integer, padThe .align directive causes the next data generated to be al ...

  6. [web 安全] xxe

    一.探测漏洞 1.是否支持实体解析. 2.是否支持外部实体解析. 2.1 直接读取本地文件: 2.2 远程文件: 3.不回显错误,则用 blind xxe.(先获取本地数据,然后带着本地数据去访问恶意 ...

  7. vue兄弟组件之前传信

    1.使用vuex 2.子传父,父传子 3.使用中央事件总线 1.新建一个js文件,然后引入vue 实例化vue 最后暴露这个实例 2.在要用的组件内引入这个组件 3.通过vueEmit.$emit(' ...

  8. Primary Key Increase by Trigger

    Oracle Create Table: CREATE TABLE TAB( ID NUMBER(10) NOT NULL PRIMARY KEY, NAME VARCHAR(19) NOT NULL ...

  9. BUUCTF |Fakebook

    1.在注册后发现这个界面,猜测是不是存在注入点 http://654000be-ea72-4eae-8074-c6cf2798c9e9.node3.buuoj.cn/view.php?no=1and1 ...

  10. R语言rvest包网络爬虫

    R语言网络爬虫初学者指南(使用rvest包) 钱亦欣 发表于 今年 06-04 14:50   5228 阅读   作者 SAURAV KAUSHIK 译者 钱亦欣 引言 网上的数据和信息无穷无尽,如 ...