题目链接:https://cn.vjudge.net/problem/POJ-3436

题意

懒得翻,找了个题意。

流水线上有N台机器装电脑,电脑有P个部件,每台机器有三个参数,产量,输入规格,输出规格;输入规格中0表示改部件不能有,1表示必须有,2无所谓;输出规格中0表示改部件没有,1表示有。问如何安排流水线(如何建边)使产量最高。

思路

建图如下



说一下为什么要拆点,若不拆点:

当每台机器节点的入度大于1且出度大于1时,经过这个节点的流量没法限制在容量下。

提交过程

AC

代码

#include <queue>
#include <cstdio>
#include <cstring>
#include <algorithm>
using namespace std;
const int maxn=50+20, INF=1e8;
struct Edge{
int from,to,cap,flow;
Edge(int u,int v,int c,int f):
from(u), to(v), cap(c), flow(f) {}
};
struct Dinic{
int n, m, s, t;
vector<int> G[maxn];
vector<Edge> edges;
bool vis[maxn];
int dep[maxn], cur[maxn];
void init(int n){
this->n=n;
for (int i=0;i<=n;i++) G[i].clear();
edges.clear();
}
void addEdge(int from, int to, int cap){
edges.push_back(Edge(from, to, cap, 0));
edges.push_back(Edge(to, from, 0, 0));
m=edges.size();
G[from].push_back(m-2);
G[to].push_back(m-1);
}
bool bfs(void){
memset(vis, false, sizeof(vis));
queue<int> Q;
vis[s]=true;
dep[s]=0; Q.push(s);
while(!Q.empty()){
int x=Q.front(); Q.pop();
for(int i=0;i<G[x].size();i++){
Edge &e=edges[G[x][i]];
if(!vis[e.to] && e.cap>e.flow){
vis[e.to]=1;
dep[e.to]=dep[x]+1;
Q.push(e.to);
}
}
}
return vis[t];
}
int dfs(int x, int a){//a当前为止所有弧的最小残量
if(x==t || a==0)return a;
int flow=0, f;
for(int &i=cur[x];i<G[x].size();i++) {//cur当前弧优化
Edge &e=edges[G[x][i]];
if(dep[e.to]==dep[x]+1 && (f=dfs(e.to, min(a, e.cap-e.flow)))>0){
e.flow+=f;
edges[G[x][i]^1].flow-=f;
flow+=f;
a-=f;
if(a==0)break;
}
}
return flow;
}
int maxFlow(int s, int t){
this->s=s; this->t=t; int flow=0;
while(bfs()){
memset(cur, 0, sizeof(cur));
flow+=dfs(s, INF);
}
return flow;
}
void bugs(void){
for (int i=0; i<=n; i++){
printf("%d: ", i);
for (int j=0; j<G[i].size(); j++)
if (edges[G[i][j]].cap!=0)
printf("%d(%d) ", edges[G[i][j]].to, edges[G[i][j]].cap);
printf("\n");
}
} void show(int st, int end){
int from[maxn*maxn], to[maxn*maxn], flow[maxn*maxn];
int size=0;
int ans=maxFlow(0, 1); if (ans==0){
printf("0 0\n");
return;
} for (int i=st; i<=end; i++){
for (int j=0; j<G[i].size(); j++){
Edge &e=edges[G[i][j]];
if (e.cap==INF && e.flow>0 && e.from!=0 && e.to!=1){
from[size]=e.from;
to[size]=e.to;
flow[size++]=e.flow;
}
}
} printf("%d %d\n", ans, size);
for (int i=0; i<size; i++)
printf("%d %d %d\n", from[i]/2, to[i]/2, flow[i]);
}
}dinic; int n, m, in[maxn][15], out[maxn][15], cap[maxn];
bool match(int j, int i){
for (int k=0; k<m; k++)
if (out[j][k]!=in[i][k] && in[i][k]!=2)
return false;
return true;
} void makeGraph(void){
for (int i=2; i<=n+1; i++){
dinic.addEdge(i*2-2, i*2-1, cap[i]);
for (int j=2; j<=n+1; j++) if (i!=j){
if (match(j, i)) dinic.addEdge(j*2-1, i*2-2, INF);
}
if (match(0, i)) dinic.addEdge(0, i*2-2, INF);
if (match(i, 1)) dinic.addEdge(i*2-1, 1, INF);
}
} int main(void){
int from, to, tmp;
while (scanf("%d%d", &m, &n)==2 && n){
dinic.init(n*2+1); for (int i=0; i<m; i++) in[1][i]=1;
for (int i=0; i<m; i++) out[0][i]=0;
for (int i=2; i<=n+1; i++){
scanf("%d", &cap[i]);
for (int j=0; j<m; j++) scanf("%d", &in[i][j]);
for (int j=0; j<m; j++) scanf("%d", &out[i][j]);
} makeGraph();
// dinic.bugs();
dinic.show(2, n*2+1);
} return 0;
}
Time Memory Length Lang Submitted
208kB 3993 C++ 2018-08-17 04:42:53

POJ-3436 ACM Computer Factory 最大流 为何拆点的更多相关文章

  1. Poj 3436 ACM Computer Factory (最大流)

    题目链接: Poj 3436 ACM Computer Factory 题目描述: n个工厂,每个工厂能把电脑s态转化为d态,每个电脑有p个部件,问整个工厂系统在每个小时内最多能加工多少台电脑? 解题 ...

  2. POJ 3436 ACM Computer Factory 最大流,拆点 难度:1

    题目 http://poj.org/problem?id=3436 题意 有一条生产线,生产的产品共有p个(p<=10)零件,生产线上共有n台(n<=50)机器,每台机器可以每小时加工Qi ...

  3. poj 3436 ACM Computer Factory 最大流+记录路径

    题目 题意: 每一个机器有一个物品最大工作数量,还有一个对什么物品进行加工,加工后的物品是什么样.给你无限多个初始都是000....的机器,你需要找出来经过这些机器操作后最多有多少成功的机器(111. ...

  4. POJ 3436 ACM Computer Factory (网络流,最大流)

    POJ 3436 ACM Computer Factory (网络流,最大流) Description As you know, all the computers used for ACM cont ...

  5. POJ - 3436 ACM Computer Factory 网络流

    POJ-3436:http://poj.org/problem?id=3436 题意 组配计算机,每个机器的能力为x,只能处理一定条件的计算机,能输出特定的计算机配置.进去的要求有1,进来的计算机这个 ...

  6. POJ - 3436 ACM Computer Factory(最大流)

    https://vjudge.net/problem/POJ-3436 题目描述:  正如你所知道的,ACM 竞赛中所有竞赛队伍使用的计算机必须是相同的,以保证参赛者在公平的环境下竞争.这就是所有这些 ...

  7. POJ 3436 ACM Computer Factory(最大流+路径输出)

    http://poj.org/problem?id=3436 题意: 每台计算机包含P个部件,当所有这些部件都准备齐全后,计算机就组装完成了.计算机的生产过程通过N台不同的机器来完成,每台机器用它的性 ...

  8. POJ 3436 ACM Computer Factory (拆点+输出解)

    [题意]每台计算机由P个零件组成,工厂里有n台机器,每台机器针对P个零件有不同的输入输出规格,现在给出每台机器每小时的产量,问如何建立流水线(连接各机器)使得每小时生产的计算机最多. 网络流的建图真的 ...

  9. POJ 3436 ACM Computer Factory

    题意:   为了追求ACM比赛的公平性,所有用作ACM比赛的电脑性能是一样的,而ACM董事会专门有一条生产线来生产这样的电脑,随着比赛规模的越来越大,生产线的生产能力不能满足需要,所以说ACM董事会想 ...

  10. kuangbin专题专题十一 网络流 POJ 3436 ACM Computer Factory

    题目链接:https://vjudge.net/problem/POJ-3436 Sample input 1 3 4 15 0 0 0 0 1 0 10 0 0 0 0 1 1 30 0 1 2 1 ...

随机推荐

  1. ZBrush中Mrgb、Rgb和M的使用

    ZBrush®软件工具架中所有的命令选项都是我们平时较为常用的,位于工具架的中间位置,有一个Mrgb.Rgb和M选项它们所表示的是材质及颜色,那么,在Zbrush中只要选择相应的选项,就可以同时绘制材 ...

  2. 纯css实现宽度自适应,高度与宽度成比例

    html: <div></div> css div{ width: 33.33%; box-sizing: border-box; float: left; position: ...

  3. 算法23-------岛屿的最大面积 LeetCode 695

    一.题目: 给定一个包含了一些 0 和 1的非空二维数组 grid , 一个 岛屿 是由四个方向 (水平或垂直) 的 1 (代表土地) 构成的组合.你可以假设二维矩阵的四个边缘都被水包围着. 找到给定 ...

  4. [luogu2059 JLOI2013] 卡牌游戏 (概率dp)

    题目描述 N个人坐成一圈玩游戏.一开始我们把所有玩家按顺时针从1到N编号.首先第一回合是玩家1作为庄家.每个回合庄家都会随机(即按相等的概率)从卡牌堆里选择一张卡片,假设卡片上的数字为X,则庄家首先把 ...

  5. linux之资料重定向

    標準輸入 (stdin) :代碼為 0 ,使用 < 或 << : 標準輸出 (stdout):代碼為 1 ,使用 > 或 >> : 標準錯誤輸出(stderr):代 ...

  6. Django REST Framework 认证 - 权限 - 限制

    一. 认证 (你是谁?) REST framework 提供了一些开箱即用的身份验证方案,并且还允许你实现自定义方案. 自定义Token认证 第一步 : 建表>>>> 定义一个 ...

  7. oracle 的交并差函数,intersect;union;minus。

    创建表并添加数据: --创建TABLE_A create table TABLE_A ( A ), B ) ); --给TABLE_A添加数据 insert into TABLE_A values(' ...

  8. 赵雅智_使用SQLiteDatabase操作SQLite数据库及事务

    知识点具体解释:http://blog.csdn.net/zhaoyazhi2129/article/details/9025995 详细代码: MainActivity.java package c ...

  9. hiho模拟面试题2 补提交卡 (贪心,枚举)

    题目: 时间限制:2000ms 单点时限:1000ms 内存限制:256MB 描写叙述 小Ho给自己定了一个雄伟的目标:连续100天每天坚持在hihoCoder上提交一个程序.100天过去了.小Ho查 ...

  10. HDU 5305 Friends (搜索+剪枝) 2015多校联合第二场

    開始对点搜索,直接写乱了.想了想对边搜索,尽管复杂度高.剪枝一下水过去了. 代码: #include<cstdio> #include<iostream> #include&l ...