POJ--2516--Minimum Cost【最小费用最大流】
链接:http://poj.org/problem?id=2516
题意:有k种货物,n个客户对每种货物有一定需求量,有m个仓库。每一个仓库里有一定数量的k种货物。然后k个n*m的矩阵,告诉从各个仓库到各个客户位置运送单位第k种货物所需的运费。问满足全部客户需求的最小费用,如满足不了全部客户,则输出-1。
思路:题目有点绕。只是多看看也就理解了。这道题算是最小费用最大流的入门题吧,建图非常easy能想到,主要是存在k种货物。每条货物都要建一条路,同一时候处理起来不好写。并且路径也较多。只是能够对每种货物分开来算。数据比較小。给了4000ms,不会超时。对每一个n*m矩阵,对于此时的货物建图。把最小费用累加起来。
假设有一种货物没法满足全部客户。即网络最大流不等于客户需求之和,则输出-1。
建图:对于每种货物单独建图。一个超级源点连向每一个客户。弧为客户对当前这样的货物的需求量,权为0。每一个仓库连向超级汇点,弧为仓库中当前这样的货物的储存量,权为0。对于n*m的矩阵,相应的客户连向相应的仓库,弧为INF,权为运送单位货物的花费。
这样的建图方式比較好想,之前也做过几道题是一样的思路。
#include<cstring>
#include<string>
#include<fstream>
#include<iostream>
#include<iomanip>
#include<cstdio>
#include<cctype>
#include<algorithm>
#include<queue>
#include<map>
#include<set>
#include<vector>
#include<stack>
#include<ctime>
#include<cstdlib>
#include<functional>
#include<cmath>
using namespace std;
#define PI acos(-1.0)
#define MAXN 500100
#define eps 1e-7
#define INF 0x7FFFFFFF
#define LLINF 0x7FFFFFFFFFFFFFFF
#define seed 131
#define mod 1000000007
#define ll long long
#define ull unsigned ll
#define lson l,m,rt<<1
#define rson m+1,r,rt<<1|1 struct node{
int u,v,w,cost,next;
}edge[MAXN];
int head[150],dist[150],pree[150],vis[150];
int n,m,k,cnt,src,sink,ans;
void add_edge(int a,int b,int c,int d){
edge[cnt].v = b;
edge[cnt].w = c;
edge[cnt].cost = d;
edge[cnt].next = head[a];
head[a] = cnt++;
}
bool spfa(){
int i,j;
queue<int>q;
q.push(src);
memset(vis,0,sizeof(vis));
for(i=0;i<=n+m+2;i++) dist[i] = INF;
dist[src] = 0;
vis[src] = 1;
while(!q.empty()){
int u = q.front();
q.pop();
vis[u] = 0;
for(i=head[u];i!=-1;i=edge[i].next){
if(edge[i].w&&dist[u]!=INF&&dist[u]+edge[i].cost<dist[edge[i].v]){
dist[edge[i].v] = dist[u] + edge[i].cost;
pree[edge[i].v] = i;
if(!vis[edge[i].v]){
vis[edge[i].v] = 1;
q.push(edge[i].v);
}
}
}
}
// for(i=0;i<=n+m+2;i++){
// cout<<dist[i]<<endl;
// }
// cout<<endl<<endl;
if(dist[sink]<INF) return true;
return false;
}
int augment(){
int i,j;
int delta = INF;
for(i=sink;i!=src;i=edge[j^1].v){
j = pree[i];
delta = min(delta,edge[j].w);
}
for(i=sink;i!=src;i=edge[j^1].v){
j = pree[i];
edge[j].w -= delta;
edge[j^1].w += delta;
ans += edge[j].cost * delta;
}
return delta;
} int ntok[60][60],ktom[60][60];
int main(){
int i,j,k;
int a,b,c,sum;
while(scanf("%d%d%d",&n,&m,&k),n||m||k){
ans = 0;
for(i=1;i<=n;i++){
for(j=1;j<=k;j++){
scanf("%d",&ntok[i][j]);
}
}
for(i=1;i<=m;i++){
for(j=1;j<=k;j++){
scanf("%d",&ktom[i][j]);
}
}
src = n + m + 2;
sink = n + m + 1;
int ii;
int flag = 0;
for(i=1;i<=k;i++){
memset(head,-1,sizeof(head));
cnt = 0;
sum = 0;
int flow = 0;
for(ii=1;ii<=n;ii++){
for(j=1;j<=m;j++){
scanf("%d",&a);
add_edge(ii,j+n,INF,a);
add_edge(j+n,ii,0,-a);
}
}
if(flag) continue;
for(ii=1;ii<=n;ii++){
add_edge(src,ii,ntok[ii][i],0);
add_edge(ii,src,0,0);
sum += ntok[ii][i];
}
for(ii=1;ii<=m;ii++){
add_edge(ii+n,sink,ktom[ii][i],0);
add_edge(sink,ii+n,0,0);
}
while(spfa()){
flow += augment();
}
if(flow!=sum) flag = 1;
}
if(flag) puts("-1");
else printf("%d\n",ans);
}
return 0;
}
POJ--2516--Minimum Cost【最小费用最大流】的更多相关文章
- POJ 2516 Minimum Cost [最小费用最大流]
题意略: 思路: 这题比较坑的地方是把每种货物单独建图分开算就ok了. #include<stdio.h> #include<queue> #define MAXN 500 # ...
- Poj 2516 Minimum Cost (最小花费最大流)
题目链接: Poj 2516 Minimum Cost 题目描述: 有n个商店,m个仓储,每个商店和仓库都有k种货物.嘛!现在n个商店要开始向m个仓库发出订单了,订单信息为当前商店对每种货物的需求 ...
- POJ2516:Minimum Cost(最小费用最大流)
Minimum Cost Time Limit: 4000MS Memory Limit: 65536K Total Submissions: 19088 Accepted: 6740 题目链 ...
- POJ2516 Minimum Cost —— 最小费用最大流
题目链接:https://vjudge.net/problem/POJ-2516 Minimum Cost Time Limit: 4000MS Memory Limit: 65536K Tota ...
- Minimum Cost(最小费用最大流)
Description Dearboy, a goods victualer, now comes to a big problem, and he needs your help. In his s ...
- POJ 2516 Minimum Cost (最小费用最大流)
POJ 2516 Minimum Cost 链接:http://poj.org/problem?id=2516 题意:有M个仓库.N个商人.K种物品.先输入N,M.K.然后输入N行K个数,每一行代表一 ...
- POJ 2516 Minimum Cost (网络流,最小费用流)
POJ 2516 Minimum Cost (网络流,最小费用流) Description Dearboy, a goods victualer, now comes to a big problem ...
- POJ - 2516 Minimum Cost(最小费用最大流)
1.K种物品,M个供应商,N个收购商.每种物品从一个供应商运送到一个收购商有一个单位运费.每个收购商都需要K种物品中的若干.求满足所有收购商需求的前提下的最小运费. 2.K种物品拆开来,分别对每种物品 ...
- POJ 2516 Minimum Cost(最小费用流)
Description Dearboy, a goods victualer, now comes to a big problem, and he needs your help. In his s ...
- POJ 2516 Minimum Cost
每个物品分开做最小费用最大流. #include<cstdio> #include<cstring> #include<cmath> #include<vec ...
随机推荐
- 紫书 习题 10-6 UVa 1210(前缀和)
素数筛然后前缀和 看代码 #include<cstdio> #include<vector> #include<cstring> #include<map&g ...
- Spring Cloud学习笔记【五】Hystrix Dashboard监控面板
ystrix除了隔离依赖服务的调用以外,Hystrix 还提供了准实时的调用监控(Hystrix Dashboard),Hystrix 会持续地记录所有通过 Hystrix 发起的请求的执行信息,并以 ...
- 開始EEPlat之旅
怎样開始EEPlat之旅 EEPlat分为社区版和商业版:功能上分为企业版和PaaS版.下面为社区企业版的開始之旅. 第一步:安装project,有两种:war包和代码project.(眼下googl ...
- 【Hibernate步步为营】--(一对多映射)之单向关联
上篇文章讨论了双向关联的一对一映射,用了两个章节,主要是从主键和外键两种关联映射展开具体讨论.双向关联的映射须要在两个映射文件里分别加入相互的相应关系.斌刚在相应的类中加入相应的关联类的属性.这样在一 ...
- 智课雅思词汇---四、clos和cap和ced是什么意思
智课雅思词汇---四.clos和cap和ced是什么意思 一.总结 一句话总结: cap/capt/cip/cep/ceiv:to take,seize(拿,抓住) cede:to go,yield( ...
- 相比于HTML4,HTML5废弃的元素有哪些?
第一类:表现性元素basefontbigcenterfontsstrikettu建议用语义正确的元素代替他们,并使用CSS来确保渲染后的效果 第二类:框架类元素因框架有很多可用性及可访问性问题,HTM ...
- OpenGL编程逐步深入(二)在窗口中显示一个点
准备知识 在本文中我们将会接触到OpenGl的扩展库GLEW( OpenGL Extension Wrangler Library),GLEW可以帮助我们处理OpenGl中繁琐的扩展管理.一旦初始化后 ...
- NARF(Normal Aligned Radial Feature)关键点
NARF(Normal Aligned Radial Feature)关键点是为了从深度图像中识别物体而提出的,对NARF关键点的提取过程有以下要求: a) 提取的过程考虑边缘以及物体表面变化信息在内 ...
- linux和Windows双系统让 Windows 把硬件时间当作 UTC
linux和Windows双系统让 Windows 把硬件时间当作 UTC Windows设置如下:开 始->运行->CMD,打开命令行程序(Vista则要以管理员方式打开命令行程序方可有 ...
- 联想 Thinkserver TS250服务器RAID1 重建测试
1.RAID1状态下,拨掉其中一块硬盘后,RAID1即失效. 2.重新插入后,在进行系统后会自动重建 *RAID1 提示Rebuild *进入桌面后软件,显示重建进度 软件下载地址:https://p ...