给出一些人,一些食物,一些饮料,每个人都只喜欢喝某些饮料,吃某些食品,每个食品和饮料都有一定的数量,现在问最多能满足多少人的需求。

注意理解题意了,每个人只需要要拿一个食物和一个饮料即可,这题目说得好像不是很明显,坑呐。

简单建模。超级源点->食物->人->人'->饮料->超级汇点。除了与源点和汇点的边容量为食物和饮料数量,其他的都为1.

跑最大流,就是答案了。。不多说

召唤代码君:

#include <iostream>
#include <cstdio>
#include <cstring>
#define maxn 1010
#define maxm 2000100
using namespace std; int first[maxn],next[maxm],to[maxm],c[maxm],N;
int d[maxn],tag[maxn],TAG=520;
int s,t,n,F,D,ans,tmp;
char str[maxn][maxn];
int Q[maxn],bot,top;
bool can[maxn]; void _init()
{
s=0,t=F+D+n+n+1,N=-1;
for (int i=s; i<=t; i++) first[i]=-1;
} void addedge(int U,int V,int W)
{
N++;
to[N]=V,c[N]=W,next[N]=first[U],first[U]=N;
N++;
to[N]=U,c[N]=0,next[N]=first[V],first[V]=N;
} void edge_build()
{
for (int i=1; i<=F; i++) scanf("%d",&tmp),addedge(s,i,tmp);
for (int i=1; i<=D; i++) scanf("%d",&tmp),addedge(F+n+n+i,t,tmp);
for (int i=1; i<=n; i++) scanf("%s",str[i]+1);
for (int i=1; i<=n; i++)
for (int j=1; j<=F; j++)
if (str[i][j]=='Y') addedge(j,F+i,1);
for (int i=1; i<=n; i++) scanf("%s",str[i]+1);
for (int i=1; i<=n; i++)
for (int j=1; j<=D; j++)
if (str[i][j]=='Y') addedge(F+n+i,F+n+n+j,1);
for (int i=1; i<=n; i++) addedge(F+i,F+n+i,1);
} bool bfs()
{
TAG++;
Q[bot=top=1]=t,d[t]=0,tag[t]=TAG,can[t]=false;
while (bot<=top)
{
int cur=Q[bot++];
for (int i=first[cur]; i!=-1; i=next[i])
if (c[i^1]>0 && tag[to[i]]!=TAG)
{
tag[to[i]]=TAG,Q[++top]=to[i],d[to[i]]=d[cur]+1,can[to[i]]=false;
if (to[i]==s) return true;
}
}
return false;
} int dfs(int cur,int num)
{
if (cur==t) return num;
int tmp=num,k;
for (int i=first[cur]; i!=-1; i=next[i])
if (c[i]>0 && tag[to[i]]==TAG && d[to[i]]==d[cur]-1 && can[to[i]]==false)
{
k=dfs(to[i],min(num,c[i]));
if (k) num-=k,c[i]-=k,c[i^1]+=k;
if (num==0) break;
}
if (num) can[cur]=true;
return tmp-num;
} int main()
{
while (scanf("%d%d%d",&n,&F,&D)!=EOF)
{
_init();
edge_build();
for (ans=0; bfs(); bfs()) ans+=dfs(s,maxm);
printf("%d\n",ans);
}
return 0;
}

  

HDU4292_Food的更多相关文章

随机推荐

  1. check the manual that corresponds to your MySQL server version for the right syntax to use near

    一.问题 mysql插入数据时报错 sql如下 insert into t_sysconfig (servercode,key,value,remark,updatetime) values (&qu ...

  2. 关于Myeclipse的MyEclipse:Java was started but returned exit code=-1 错误

    我们在安装MyEclipse后有时会遇到这样一个问题,可以进入主界面软件也属于激活状态,但是过一会会报错, 并弹出MyEclipse:Java was started but returned exi ...

  3. PSR编码规范

    PSR-1 代码风格规范(1)常量命名:类中的常量所有字母都必须大写,单词间用下划线分隔(2)类命名:类的命名必须遵循 StudlyCaps 大写开头的驼峰命名规范(3)方法命名:方法名称必须符合 c ...

  4. Error! Failed to install react, react-dom, next, try again.

    问题:用create-next-app创建应用报错,部分模块没有安装,react.react-dom.next等模块安装失败,如下图所示 操作环境: 系统:Ubuntu 16.04.4 LTS npm ...

  5. Android Library开发注意事项

    Android Library开发注意事项 App Module添加依赖Android Library时可以设置library的优先级, 在编译时,app按照library从低到高的优先级依次与每个l ...

  6. 详细介绍svn在eclipse中的使用(附图解说明)

    SVN是Subversion的简称,是一个开放源代码的版本控制系统,相较于RCS.CVS,它采用了分支管理系统,它的设计目标就是取代CVS.互联网上很多版本控制服务已从CVS迁移到Subversion ...

  7. 【坚持】Selenium+Python学习之从读懂代码开始 DAY7

    2018/05/25 EC [EC](https://github.com/easonhan007/webdriver_guide/blob/master/34/expected_conditions ...

  8. kali linux执行apt-get update失败(数字签名过期)

    想要安装某个软件,执行apt-get update 失败,出现下面的错误: 自己查看了更新源是没有问题的,根据提示的错误google了一下,发现是数字签名过期了. 执行下面命令: apt-key ad ...

  9. uiimageview 的 animation 动画

    NSMutableArray *meiArr = [NSMutableArray arrayWithCapacity:4]; for (int i = 0; i < 4; i++) { NSSt ...

  10. Python List Comprehension

    (一)使用List Comprehension的好处 在了解Python的List Comprehension之前,我们习惯使用for循环创建列表,比如下面的例子: numbers = range(1 ...