POJ 3436 ACM Computer Factory

电脑公司生产电脑有N个机器。每一个机器单位时间产量为Qi。

电脑由P个部件组成,每一个机器工作时仅仅能把有某些部件的半成品电脑(或什么都没有的空电脑)变成有还有一些部件的半成品电脑或完整电脑(也可能移除某些部件)。求电脑公司的单位时间最大产量,以及哪些机器有协作关系,即一台机器把它的产品交给哪些机器加工。

Sample input

3 4

15  0 0 0  0 1 0

10  0 0 0  0 1 1

30  0 1 2  1 1 1

3    0 2 1  1 1 1

Sample output

25 2

1 3 15

2 3 10

输入:电脑由3个部件组成。共同拥有4台机器,1号机器产量15, 能给空电脑加上2号部件,2号 机器能给空电脑加上2号部件和3号部件, 3号机器能把有1个2号部件和3号部件有无均可的电脑变成成品(每种部件各有一个)

输出:单位时间最大产量25,有两台机器有协作关系。

1号机器单位时间内要将15个电脑给3号机器加工

2号机器单位时间内要将10个电脑给3号机器加工

数据规模非常小,用EdmondsKarp就能够了。主要题目不仅要求最大流的值还要输出有流流过的边。

细致想一想。这题不用拆点!

#include<cstdio>
#include<cstring>
#include<algorithm>
#include<queue>
#include<vector> using namespace std; typedef long long LL;
const int maxn = 60;
const int inf = 0x7fffffff; 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 EdmondsKarp {
int n,m;
vector<Edge> edges;
vector<int> G[maxn];
int p[maxn];
int a[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);
} int Maxflow(int s,int t)
{
int flow=0;
while(true) {
memset(a,0,sizeof(a));
queue<int> Q;
Q.push(s);
a[s]=inf;
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(!a[e.to]&&e.cap>e.flow) {
a[e.to]=min(a[x],e.cap-e.flow);
p[e.to]=G[x][i];
Q.push(e.to);
if(e.to==t)
break;
}
}
if(a[t])break;
}
if(!a[t])break;
for(int u=t; u!=s; u=edges[p[u]].from) {
edges[p[u]].flow+=a[t];
edges[p[u]^1].flow-=a[t];
}
flow+=a[t];
}
return flow;
}
}; EdmondsKarp solver; int P, N;
int w[maxn], in[maxn][12], out[maxn][12]; int print[maxn][5], cnt;
int main()
{
int i, j;
bool flag;
while(~scanf("%d%d", &P, &N)) {
int s = 0, t = N+1;
solver.init(N+2);
for(int i=1; i<=N; ++i) {
scanf("%d", &w[i]);
flag = true;
for(j=0; j<P; ++j) {
scanf("%d", &in[i][j]);
if(in[i][j]==1) flag = false;
}
if(flag) solver.AddEdge(s, i, w[i]); flag = true;
for(j=0; j<P; ++j) {
scanf("%d", &out[i][j]);
if(out[i][j]!=1) flag = false;
}
if(flag) solver.AddEdge(i, t, w[i]);
}
for(i=1; i<=N; ++i) {
for(j=1; j<=N; ++j) {
if(i==j) continue;
flag = true;
for(int k=0; k<P; ++k)
if(out[i][k] + in[j][k] == 1) {
flag = false;
break;
}
if(flag) solver.AddEdge(i, j, min(w[i], w[j]));
}
} printf("%d ", solver.Maxflow(s, t));
cnt = 0;
for(i=1; i<=N; ++i)
for(j=0; j<solver.G[i].size(); ++j)
{
Edge &e = solver.edges[solver.G[i][j]];
if(e.flow>0 && e.to != t && e.from != s)
{
print[cnt][0] = e.from;
print[cnt][1] = e.to;
print[cnt++][2] = e.flow;
}
}
printf("%d\n", cnt);
for(i=0; i<cnt; ++i)
printf("%d %d %d\n", print[i][0],print[i][1],print[i][2]);
}
return 0;
}

poj3436 ACM Computer Factory, 最大流,输出路径的更多相关文章

  1. POJ3436 ACM Computer Factory —— 最大流

    题目链接:https://vjudge.net/problem/POJ-3436 ACM Computer Factory Time Limit: 1000MS   Memory Limit: 655 ...

  2. poj-3436.ACM Computer Factory(最大流 + 多源多汇 + 结点容量 + 路径打印 + 流量统计)

    ACM Computer Factory Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 10940   Accepted:  ...

  3. POJ-3436-ACM Computer Factory(最大流, 输出路径)

    链接: https://vjudge.net/problem/POJ-3436#author=0 题意: 为了追求ACM比赛的公平性,所有用作ACM比赛的电脑性能是一样的,而ACM董事会专门有一条生产 ...

  4. POJ3436 ACM Computer Factory(最大流)

    题目链接. 分析: 题意很难懂. 大体是这样的:给每个点的具体情况,1.容量 2.进入状态 3.出去状态.求最大流. 因为有很多点,所以如果一个点的出去状态满足另一个点的进入状态,则这两个点可以连一条 ...

  5. POJ-3436 ACM Computer Factory 最大流 为何拆点

    题目链接:https://cn.vjudge.net/problem/POJ-3436 题意 懒得翻,找了个题意. 流水线上有N台机器装电脑,电脑有P个部件,每台机器有三个参数,产量,输入规格,输出规 ...

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

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

  7. POJ3436 ACM Computer Factory 【最大流】

    ACM Computer Factory Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 5412   Accepted: 1 ...

  8. POJ3436 ACM Computer Factory(最大流/Dinic)题解

    ACM Computer Factory Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 8944   Accepted: 3 ...

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

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

随机推荐

  1. Android lrucache 实现与使用(Android内存优化)

    什么是LruCache? LruCache实现原理是什么? 这两个问题其实可以作为一个问题来回答,知道了什么是 LruCache,就只然而然的知道 LruCache 的实现原理:Lru的全称是Leas ...

  2. HDU - 4511 小明系列故事――女友的考验(AC自己主动机+DP)

    Description 最终放寒假了,小明要和女朋友一起去看电影.这天,女朋友想给小明一个考验,在小明正准备出发的时候.女朋友告诉他.她在电影院等他,小明过来的路线必须满足给定的规则:  1.如果小明 ...

  3. CListCtrl的Report风格自绘

    原文链接: http://jingyan.baidu.com/article/5bbb5a1b38af1113eaa17910.html CListCtrl是MFC中运用最广泛的控件之一,很多软件都有 ...

  4. 记一次Linux系统安装的异常(AMI配置)

    一.背景 安装Linux系统(Debian 8.8),老是失败,卡在Install Software (12%的位置) 二.解决? 网上搜到的解决方法 1. 安装过程中不要拔网线(我没拔) 2. 安装 ...

  5. 从代码上解决Jenkins 发送邮件中文乱码问题

    在实践中,使用Jenkins发送测试报告,收到邮件,邮件内容中的中文为乱码,邮件发送的方式是在Jenkins发邮件设置中设置邮件内容为:${FILE,path="report_ug.html ...

  6. Latex中如何设置字体颜色(3种方式)

    Latex中如何设置字体颜色(三种方式)   1.直接使用定义好的颜色 \usepackage{color} \textcolor{red/blue/green/black/white/cyan/ma ...

  7. Windows 7 添加SSD硬盘后重启卡住正在启动

    楼主办公电脑,原来只配置了一块机械硬盘,用着总很不顺心,于是说服领导给加了块SSD固态硬盘. 操作如下: 1.在PE下分区格式化新固态硬盘,将原来机械硬盘的C盘GHOST备份后还原到新固态硬盘: 2. ...

  8. MySql(十七):MySql架构设计——高可用设计之思路及方案

    前言: 数据库系统是一个应用系统的核心部分,要想系统整体可用性得到保证,数据库系统就不能出现任何问题.对于一个企业级的系统来说,数据库系统的可用性尤为重要.数据库系统一旦出现问题无法提供服务,所有系统 ...

  9. GCD 实现生产-消费 模式

    #import "ViewController.h" @interface ViewController (){ } @property (nonatomic,strong) di ...

  10. Java:多线程,CyclicBarrier同步器

    1. 背景 CyclicBarrier类,它允许一组线程互相等待,直到到达某个公共屏障点 (common barrier point).在涉及一组固定大小的线程的程序中,这些线程必须不时地互相等待,此 ...