NKOI 1940 圆桌问题
来源:互联网 发布:java bufferedwriter 编辑:程序博客网 时间:2024/04/29 16:35
【线性规划与网络流24题 5】圆桌问题
Time Limit:10000MS Memory Limit:65536K
Total Submit:34 Accepted:26
Case Time Limit:1000MS
Description
假设有来自 n 个不同单位的代表参加一次国际会议。每个单位的代表数分别为ri, i=1,2,...,n。会议餐厅共有 m张餐桌,每张餐桌可容纳 ci(i=1,2,...,m) 个代表就餐。为了使代表们充分交流, 希望从同一个单位来的代表不在同一个餐桌就餐。
试设计一个算法,给出满足要求的代表就餐方案。
编程任务:
对于给定的代表数和餐桌数以及餐桌容量,编程计算满足要求的代表就餐方案
由于本OJ无Special Judge , 所以只需要输出能否满足要求
Input
第1行有 2 个正整数m和 n,m表示单位数,n表示餐桌数,1<=m<=150, 1<=n<=270。
文件第 2 行有m个正整数,分别表示每个单位的代表数。
文件第3行有n个正整数,分别表示每个餐桌的容量。
Output
程序运行结束时,将代表就餐方案输出。
如果问题有解,在文件第1行输出1,否则输出0。
Sample Input
4 5 4 5 3 5 3 5 2 6 4
Sample Output
1
Source
感谢 Wo_ai_WangYuan 修改题目并放上数据
这道题我们可以将源点与每一个单位连接,容量为单位人数
将每一个单位与每一个桌子连接,容量为1(即每个桌子不能呆多个同一单位的人)
将每一个桌子和汇点连接,容量为桌子能坐的人数,求最大流
如果最大流和总人数相等为1,否则就为0
#include<cstdio>#include<iostream>using namespace std;const int inf=1e9;int m,n,g[600][600],op,ed;int dis[600],vd[600];int dfs(int u,int flow){ if(u==ed)return flow; int v,temp,delta=0; for(v=1;v<=ed;v++) if(g[u][v]&&dis[u]==dis[v]+1){ temp=dfs(v,min(flow-delta,g[u][v])); g[u][v]-=temp; g[v][u]+=temp; delta+=temp; if(delta==flow||dis[0]>=ed)return delta; } if(dis[0]>=ed)return delta; vd[dis[u]]--; if(vd[dis[u]]==0)dis[0]=ed; dis[u]++; vd[dis[u]]++; return delta; }int main(){int i,j,x,y;int sum=0;cin>>m>>n;op=m+n+1,ed=op+1;for(i=1;i<=m;i++){cin>>x;sum+=x;g[op][i]=x;}for(i=1;i<=n;i++){cin>>x;g[i+m][ed]=x;}for(i=1;i<=m;i++) for(j=1+m;j<=m+n;j++) g[i][j]=1;int ans=0;while(dis[0]<ed)ans+=dfs(op,inf);printf("%d",ans==sum);}
0 0
- NKOI 1940 圆桌问题
- 圆桌问题
- 圆桌问题
- 圆桌问题
- 圆桌问题
- 圆桌问题
- 圆桌问题
- NKOI 2457 矩阵问题
- Josephus问题(圆桌骑士)
- 圆桌吃饭问题
- 1487 圆桌问题
- hdu4841 圆桌问题
- hdu4841.圆桌问题
- hdoj圆桌问题
- HDU 4841 圆桌问题
- HDOJ 圆桌问题 4841
- hdu 4841 圆桌问题
- 搬圆桌问题
- LEETCODE SQL题目 180. Consecutive Numbers
- JAVA学习笔记 ---equals、hashcode和==的区别
- #2 大话机器学习中的贝叶斯 Bayesian
- HDU 5053 the Sum of Cube
- scrapy和scrapyd-client的使用教程
- NKOI 1940 圆桌问题
- 日期类与初识集合
- libevent简介和使用
- Ubuntu14.04LTS安装TensorFlow
- HTML5-Web Workers
- ZZULI OJ 1894: 985的方格难题
- 毕业五年决定你的一生
- Linux动态链接(4)ldd与ldconfig
- POJ-2485 Highways(Kruscal)