如何建图?

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

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

  起点到食物层边的容量是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. 浅谈格雷码(Grey Code)在信息学竞赛中的应用

    1.格雷码的概念 1.性质 格雷码(Grey Code),又叫循环二进制码或反射二进制码,是一种编码方式,它的基本特点是任意两个相邻的格雷码只有一位二进制数不同. 常用的二进制数与格雷码间的转换关系如 ...

  2. linux安装curl出错

    今天配置一台server的php支持curl的时候, 出现如下报错 checking for cURL in default path... not foundconfigure: error: Pl ...

  3. Git:将本地项目连接到远程(github、gitee、gitlab)仓库流程

    当进行协同开发或者为了代码安全备份需要,一般都会将本地代码和远程仓库相连接. 备注:Github.Gitee.Gitlab是三个常用的远程git仓库,操作流程基本一致. 提前环境要求: 1.node. ...

  4. [好好学习]在VMware中安装Oracle Enterprise Linux (v5.7) - (4/5)

  5. ASE Beta Sprint - backend scrum 1

    本次scrum于2019.12.2与前端组和模型组一起在sky garden进行,持续50分钟. 参与人: Xin Kang, Zhikai Chen, Lihao Ran, Hao Wang 请假: ...

  6. openstack stein部署手册 6. nova-api

    # 建立数据库用户及权限 create database nova; grant all privileges on nova.* to nova@'localhost' identified by ...

  7. Maya2019下载安装与激活

    目录 1. 更多推荐 2. 下载地址 2.1. OneDrive 2.2. Window (64位) 2.3. MAC_OSX 3. 安装激活教程 1. 更多推荐 其他Maya版本的下载与激活:htt ...

  8. Unity 官网无法访问|国外网站访问过慢|国外网站访问加速器

    目录 1. 文档地址 2. 按 3. 工具下载地址 1. 文档地址 GitHub博客 https://coco5666.github.io/blog/articles/20190704-01/ 2. ...

  9. Java实现代理服务器

    Web代理(proxy)服务器是网络的中间实体. 代理位于Web客户端和Web服务器之间,扮演"中间人"的角色. HTTP的代理服务器即是Web服务器又是Web客户端. 代理服务器 ...

  10. Windows结束某个端口的进程

    1.打开cmd命令窗口,输入命令:netstat -ano | findstr 8080,根据端口号查找对应的PID.结果如下: 发现8080端口被PID(进程号)为2188的进程占用. 2.根据PI ...