POJ 3436 ACM Computer Factory
题意:
为了追求ACM比赛的公平性,所有用作ACM比赛的电脑性能是一样的,而ACM董事会专门有一条生产线来生产这样的电脑,随着比赛规模的越来越大,生产线的生产能力不能满足需要,所以说ACM董事会想要重新建造一条生产线。
生产线是全自动化的,所以需要机器来组成生产线,给定有多少中种机器,标准ACM用电脑有多少部份,每种机器将什么样的ACM电脑半成品处理成什么样的电脑半成品(对于输入的电脑半成品,每部分有0,1,2三种状态:代表着 0、这部分必须没有我才能处理,1、这部分必须有我才能处理,2、这部分有没有我都能处理。对于输出的电脑半成品有0,1两种状态:代表着0,处理完后的电脑半成品里没有这部分,1、处理完的电脑半成品有这部分),每一个机器每小时可以处理Q个半成品(输入数据中的Qi)。
求组装好的成产线的最大工作效率(每小时最多生成多少成品,成品的定义就是所有部分的状态都是“1”)



#include<cstdio>
#include<cstring>
#include<iostream>
#include<algorithm>
#include<cmath>
#include<queue>
using namespace std;
typedef long long LL;
const int INF = 1e9+;
const int maxn = ;
const int MOD = 1e9+; int G[maxn][maxn], Layer[maxn], G2[maxn][maxn];
struct node
{
int in[], out[];///第i台机器的输入输出规格
int flow;///第i台机器能放出的最大流量
} P[maxn];
int n, m;///n台机器,每台机器需要m个零件 bool OK(int a,int b)
{
for(int i=; i<=m; i++)
{
if( !(P[a].out[i] == P[b].in[i] || P[b].in[i] == ) )
return false;
}
return true;
} bool BFS(int Star,int End)
{
memset(Layer, , sizeof(Layer));
Layer[Star] = ;
queue<int> Q;
Q.push(Star); while( Q.size() )
{
int s = Q.front();
Q.pop(); if(s == End) return true; for(int i=; i<= End; i++)
{
if(G[s][i] && !Layer[i])
{
Layer[i] = Layer[s] + ;
Q.push(i);
}
}
}
return false;
}
int DFS(int s,int End, int MaxFlow)
{
if(s == End) return MaxFlow; int sFlow = ;///从s出发到达汇点的最大流量 for(int i=; i<=End; i++)
{
int flow = G[s][i]; if( G[s][i]== || Layer[s]+ != Layer[i] ) continue; flow = min(MaxFlow-sFlow, flow);
flow = DFS(i, End, flow);
G[s][i] -= flow;
G[i][s] += flow;
sFlow += flow;
if(sFlow == MaxFlow)
break ;
}
if(sFlow == )
Layer[s] = ;
return sFlow;
} int Dinic(int Star,int End)
{
int ans = ;
while( BFS(Star, End) )
{
ans += DFS(Star, End, INF);
}
return ans;
} int main()
{ while(scanf("%d %d", &m, &n) != EOF)
{
memset(G, , sizeof(G));
memset(P, , sizeof(P));
for(int i=; i<=n; i++)
{
scanf("%d", &P[i].flow);
for(int j=; j<=m; j++)
scanf("%d", &P[i].in[j]); for(int j=; j<=m; j++)
scanf("%d", &P[i].out[j]);
}
for(int i=; i<=m; i++)
{
P[].in[i] = P[].out[i] = ;
P[n+].in[i] = P[n+].out[i] = ;
}
P[].flow = P[n+].flow = INF;
n ++; for(int i=; i<=n; i++)
for(int j=; j<=n; j++)
{
if(i == j)
G[j+n][i] = P[i].flow;
else if( OK(i, j) )
G[i][j+n] = P[i].flow;
}
memcpy(G2, G, sizeof(G));
int MaxFlow = Dinic(, n*);
int num = , a[maxn], b[maxn], c[maxn]; for(int i=; i<n; i++)
for(int j=; j<n; j++)
{
if(i == j)continue; if(G2[i][j+n] > G[i][j+n])
{
a[num] = i, b[num] = j;
c[num++] = G2[i][j+n] - G[i][j+n];
}
} printf("%d %d\n", MaxFlow, num); for(int i=; i<num; i++)
printf("%d %d %d\n", a[i], b[i], c[i]); }
return ;
}
/*
3 5
5 0 0 0 0 1 0
100 0 1 0 1 0 1
3 0 1 0 1 1 0
1 1 0 1 1 1 0
300 1 1 2 1 1 1
*/
POJ 3436 ACM Computer Factory的更多相关文章
- POJ 3436 ACM Computer Factory (网络流,最大流)
POJ 3436 ACM Computer Factory (网络流,最大流) Description As you know, all the computers used for ACM cont ...
- Poj 3436 ACM Computer Factory (最大流)
题目链接: Poj 3436 ACM Computer Factory 题目描述: n个工厂,每个工厂能把电脑s态转化为d态,每个电脑有p个部件,问整个工厂系统在每个小时内最多能加工多少台电脑? 解题 ...
- POJ - 3436 ACM Computer Factory 网络流
POJ-3436:http://poj.org/problem?id=3436 题意 组配计算机,每个机器的能力为x,只能处理一定条件的计算机,能输出特定的计算机配置.进去的要求有1,进来的计算机这个 ...
- POJ 3436 ACM Computer Factory 最大流,拆点 难度:1
题目 http://poj.org/problem?id=3436 题意 有一条生产线,生产的产品共有p个(p<=10)零件,生产线上共有n台(n<=50)机器,每台机器可以每小时加工Qi ...
- POJ 3436 ACM Computer Factory(最大流+路径输出)
http://poj.org/problem?id=3436 题意: 每台计算机包含P个部件,当所有这些部件都准备齐全后,计算机就组装完成了.计算机的生产过程通过N台不同的机器来完成,每台机器用它的性 ...
- POJ - 3436 ACM Computer Factory(最大流)
https://vjudge.net/problem/POJ-3436 题目描述: 正如你所知道的,ACM 竞赛中所有竞赛队伍使用的计算机必须是相同的,以保证参赛者在公平的环境下竞争.这就是所有这些 ...
- POJ 3436 ACM Computer Factory (拆点+输出解)
[题意]每台计算机由P个零件组成,工厂里有n台机器,每台机器针对P个零件有不同的输入输出规格,现在给出每台机器每小时的产量,问如何建立流水线(连接各机器)使得每小时生产的计算机最多. 网络流的建图真的 ...
- 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 ...
- poj 3436 ACM Computer Factory 最大流+记录路径
题目 题意: 每一个机器有一个物品最大工作数量,还有一个对什么物品进行加工,加工后的物品是什么样.给你无限多个初始都是000....的机器,你需要找出来经过这些机器操作后最多有多少成功的机器(111. ...
随机推荐
- Android热门网络框架Volley详解
.Volley简介 volley的英文意思为‘群发’.‘迸发’.Volley是2013年谷歌官方发布的一款Android平台上的网络通信库.Volley非常适合一些数据量不大,但需要频繁通信的网络操作 ...
- cocos2dx Hello world 创建
环境搭建好后,就要开始创建自己的第一个hello world项目了 因为没有安装其他的插件,所以最开始只能手动创建 首先通过cmd 进入你的cocos2dx的路径下: D:\soft\cocos2d- ...
- (转)修改ECSHOP前后台的title中的ecshop
前台部分: 1:去掉头部TITLE部分的ECSHOP演示站 Powered by ecshop 前者在后台商店设置 - 商店标题修改 后者打开includes/lib_main.php $page_t ...
- android listview 替代品recyclerview详解
安卓v7支持包下的ListView替代品————RecyclerView RecyclerView这个控件也出来很久了,相信大家也学习的差不多了,如果还没学习的,或许我可以带领大家体验一把这个艺术 ...
- 【POJ1442】【Treap】Black Box
Description Our Black Box represents a primitive database. It can save an integer array and has a sp ...
- 泛型? extents super
?可以接受任何泛型集合,但是不能编辑集合值.所以一般只在方法参数中用 例子: ? extends Number 则类型只能是Number类的子孙类 ? super String 则类型只能是Str ...
- javaScript 的option触发事件
先说jquery的option触发事件,很方便 $("option:selected")//这样就能直接触发选择的option了 在JavaScript中就显得比较麻烦,其实< ...
- PHP框架_Smarty_实现登录功能
1.项目框架 |--mvc |--data 数据 |--cache 缓存 |--template_c 模板生成目录 |--framework |--function |--function.php 功 ...
- php之购物车类思路及代码
<?php /* 购物车类 1.整站范围内,购物车--全局有效 解决:把购物车的信息,放在session里 2.既然全局有效,购物车的实例只有一个 解决:单例模式 技术选型:session+单例 ...
- 原生Ajax + Promise
有原生写的ajax + promise嫁接下 ;(function(root){ var LD = function(obj){ if( obj instanceof LD ) return obj; ...