LG1402 酒店之王
题意
XX酒店的老板想成为酒店之王,本着这种希望,第一步要将酒店变得人性化。由于很多来住店的旅客有自己喜好的房间色调、阳光等,也有自己所爱的菜,但是该酒店只有p间房间,一天只有固定的q道不同的菜。
有一天来了n个客人,每个客人说出了自己喜欢哪些房间,喜欢哪道菜。但是很不幸,可能做不到让所有顾客满意(满意的条件是住进喜欢的房间,吃到喜欢的菜)。
这里要怎么分配,能使最多顾客满意呢?
\(n,p,q \leq 100\)
分析
将人拆成两个点,中间加一条容量为1的边。
然后源点连房间,房间连人,人连菜,菜连汇点,跑最大流就行了。
时间复杂度\(O(n^4)\)
代码
#include<iostream>
#include<cstring>
#include<cmath>
#include<cstdio>
#include<set>
#include<map>
#include<queue>
#include<vector>
#include<algorithm>
#include<string>
template<class T>T read(T&x)
{
T data=0;
int w=1;
char ch=getchar();
while(!isdigit(ch))
{
if(ch=='-')
w=-1;
ch=getchar();
}
while(isdigit(ch))
{
data=data*10+ch-'0';
ch=getchar();
}
return x=data*w;
}
using namespace std;
const int INF=0x3f3f3f3f;
const int MAXN=407,MAXM=5e4+7;
int n,p,q; // people,room,meal
struct edge
{
int nx,to,c;
}e[MAXM];
int head[MAXN],ecnt;
void addedge(int x,int y,int c)
{
e[++ecnt].to=y,e[ecnt].c=c;
e[ecnt].nx=head[x],head[x]=ecnt;
}
int dep[MAXN],cur[MAXN];
queue <int> Q;
bool bfs(int s,int t)
{
copy(head,head+t+1,cur);
fill(dep+s,dep+t+1,INF);
dep[s]=0;
Q.push(s);
while(Q.size())
{
int x=Q.front();
Q.pop();
for(int i=head[x];i!=-1;i=e[i].nx)
{
int y=e[i].to,c=e[i].c;
if(c>0&&dep[y]==INF)
{
dep[y]=dep[x]+1;
Q.push(y);
}
}
}
return dep[t]<INF;
}
int dfs(int x,int t,int lim)
{
if(x==t||!lim)
return lim;
int delta=0,inc;
for(int i=cur[x];i!=-1;i=e[i].nx)
{
cur[x]=i;
int y=e[i].to,c=e[i].c;
if(dep[y]==dep[x]+1&&(inc=dfs(y,t,min(lim,c))))
{
lim-=inc;
delta+=inc;
e[i].c-=inc;
e[i^1].c+=inc;
if(!lim)
break;
}
}
return delta;
}
int Dinic(int s,int t)
{
int res=0;
while(bfs(s,t))
res+=dfs(s,t,INF);
return res;
}
int main()
{
// freopen(".in","r",stdin);
// freopen(".out","w",stdout);
read(n);read(p);read(q);
fill(head,head+p+2*n+q+2,-1);
ecnt=-1;
for(int i=1;i<=p;++i)
{
addedge(0,i,1);
addedge(i,0,0);
}
for(int i=1;i<=n;++i)
for(int j=1;j<=p;++j)
{
int opt;
read(opt);
if(opt)
{
addedge(j,p+i,1);
addedge(p+i,j,0);
}
}
for(int i=1;i<=n;++i)
{
addedge(p+i,p+n+i,1);
addedge(p+n+i,p+i,0);
}
for(int i=1;i<=n;++i)
for(int j=1;j<=q;++j)
{
int opt;
read(opt);
if(opt)
{
addedge(p+n+i,p+2*n+j,1);
addedge(p+2*n+j,p+n+i,0);
}
}
for(int i=1;i<=q;++i)
{
addedge(p+2*n+i,p+2*n+q+1,1);
addedge(p+2*n+q+1,p+2*n+i,0);
}
int ans=Dinic(0,p+2*n+q+1);
printf("%d\n",ans);
return 0;
}
LG1402 酒店之王的更多相关文章
- Luogu 1402 酒店之王(二分图最大匹配)
Luogu 1402 酒店之王(二分图最大匹配) Description XX酒店的老板想成为酒店之王,本着这种希望,第一步要将酒店变得人性化.由于很多来住店的旅客有自己喜好的房间色调.阳光等,也有自 ...
- 洛谷P2891 Dining P1402 酒店之王【类二分图匹配】题解+代码
洛谷P2891 Dining P1402 酒店之王[类二分图匹配]题解+代码 酒店之王 题目描述 XX酒店的老板想成为酒店之王,本着这种希望,第一步要将酒店变得人性化.由于很多来住店的旅客有自己喜好的 ...
- luogu1402 酒店之王
题目描述 XX酒店的老板想成为酒店之王,本着这种希望,第一步要将酒店变得人性化.由于很多来住店的旅客有自己喜好的房间色调.阳光等,也有自己所爱的菜,但是该酒店只有p间房间,一天只有固定的q道不同的菜. ...
- [Luogu 1402] 酒店之王
题目 Description XX酒店的老板想成为酒店之王,本着这种希望,第一步要将酒店变得人性化.由于很多来住店的旅客有自己喜好的房间色调.阳光等,也有自己所爱的菜,但是该酒店只有p间房间,一天只有 ...
- [luogu1402]酒店之王_网络流
酒店之王 luogu-1402 题目大意:有n个人,p道菜,q个房间,每个人喜欢吃一些菜.喜欢住一些房间,如果一个人即住到了他喜欢的房间有吃到了他喜欢的菜,就对答案贡献++,求最大贡献. 注释:1&l ...
- P1402 酒店之王
P1402 酒店之王 每个人要匹配一个A和一个B,所以这样连边: S向每个房间连边. 每个房间向喜欢这个房间的人连边. 每个人向喜欢的菜连边. 每道菜向T连边. 边权均为1. 注意人要限流. // I ...
- 【刷题】洛谷 P1402 酒店之王
题目描述 XX酒店的老板想成为酒店之王,本着这种希望,第一步要将酒店变得人性化.由于很多来住店的旅客有自己喜好的房间色调.阳光等,也有自己所爱的菜,但是该酒店只有p间房间,一天只有固定的q道不同的菜. ...
- P1402 酒店之王 最大流
\(\color{#0066ff}{ 题目描述 }\) XX酒店的老板想成为酒店之王,本着这种希望,第一步要将酒店变得人性化.由于很多来住店的旅客有自己喜好的房间色调.阳光等,也有自己所爱的菜,但是该 ...
- luogu P1402 酒店之王
题目描述 XX酒店的老板想成为酒店之王,本着这种希望,第一步要将酒店变得人性化.由于很多来住店的旅客有自己喜好的房间色调.阳光等,也有自己所爱的菜,但是该酒店只有p间房间,一天只有固定的q道不同的菜. ...
随机推荐
- Android和iOS中Cocos2dx的横屏竖屏设置
一.横屏.竖屏设置 1.android AndroidManifest.xml文件中, screenOrientation="landscape" 为横屏, screenOrien ...
- 设计模式--原型模式C++实现
原型模式C++实现 1定义 用原型实例指定创建对象的种类,并且通过拷贝这些原型创建新的对象 2类图 3实现 class Prototype { protected: Prototype(); publ ...
- poj2187凸包最远点对
暴力过了 #include<map> #include<set> #include<cmath> #include<queue> #include< ...
- 1-15-2-RAID5 企业级RAID磁盘阵列的搭建(RAID1、RAID5、RAID10)
RAID5的搭建 第一步:添加四个磁盘,开机并检查(略过) 第二步:使用fdisk命令分别对四个磁盘进行分区,效果如下图: 第三步:使用mdadm命令创建RAID5磁盘阵列 [root@localho ...
- syslinux启动盘制作
# <font color=DarkCyan >syslinux启动盘制作</font> # ### 准备工具 ### 1. BOOTICEx64 软件 ##分区引导制作工具 ...
- OC与JS的交互详解
事情的起因还是因为项目需求驱动.折腾了两天,由于之前没有UIWebView与JS交互的经历,并且觉得这次在功能上有一定的创造性,特此留下一点文字,方便日后回顾. 我要实现这样一个需求:按照本地的CSS ...
- ie下的bug之button
场景描述: 现在页面设计是都喜欢自定义按钮样式,某日接收到页面发现在ie下有bug,上代码: <div> <button><span><a href=&quo ...
- HDU 3473 Minimum Sum 划分树,数据结构 难度:1
http://acm.hdu.edu.cn/showproblem.php?pid=3473 划分树模板题目,需要注意的是划分树的k是由1开始的 划分树: 参考:http://blog.csdn.ne ...
- Week08《Java程序设计》第八次学习总结
Week08<Java程序设计>第八次学习总结 1. 本周学习总结 以你喜欢的方式(思维导图或其他)归纳总结集合相关内容. 答: 2.书面作业 1. ArrayList代码分析 1.1 解 ...
- IIS站点/虚拟目录中访问共享目录(UNC)以及建立后的应用程序的信任级别问题
UNC是 Universal Naming Convention 的简称,也叫通用命名规范.通用命名约定.网络(范指局域网)上资源的完整位置名称.格式为 \\servername\sharenam ...