http://poj.org/problem?id=2516

 #include<cstdio>
#include<cstring>
#include<algorithm>
#include<queue>
#define maxn 110
using namespace std; int need[maxn][maxn];
int sup[maxn][maxn];
int cost[maxn][maxn][maxn];
int cap[maxn][maxn];
int flow[maxn][maxn];
int cost1[maxn][maxn];
int d[maxn];
int p[maxn];
int n,m,k;
const int inf=<<; int main()
{
while(scanf("%d%d%d",&n,&m,&k)!=EOF){
memset(p,,sizeof(p));
memset(cost1,,sizeof(cost1));
memset(need,,sizeof(need));
if(n==&&m==&&k==) break;
for(int i=; i<=n; i++){
for(int j=; j<=k; j++)
{
scanf("%d",&need[i][j]);
}
}
for(int i=; i<=m; i++)
{
for(int j=; j<=k; j++)
{
scanf("%d",&sup[i][j]);
}
}
for(int c=; c<=k; c++)
{
for(int i=; i<=n; i++)
{
for(int j=; j<=m; j++)
{
scanf("%d",&cost[c][j][i]);
}
}
}
int s=,t=n+m+;
bool flag=true;
int tt=;
for(int i=; i<=k; i++)
{
memset(cap,,sizeof(cap));
for(int j=; j<=m; j++)
cap[s][j]=sup[j][i];
for(int j=; j<=m; j++)
{
for(int c=; c<=n; c++)
{
cap[j][m+c]=sup[j][i];
}
}
for(int j=; j<=m; j++)
cap[j+m][t]=need[j][i];
memset(flow,,sizeof(flow));
for(int j=; j<=m; j++)
{
for(int c=; c<=n; c++)
{
cost1[j][c+m]=cost[i][j][c];
cost1[c+m][j]=-cost1[j][c+m];
}
}
queue<int>q;
memset(flow,,sizeof(flow));
int mm=;
for(;;)
{
bool inq[maxn];
for(int i=; i<=n+m+; i++) d[i]=(i==s?:inf);
memset(inq,false,sizeof(inq));
q.push(s);
while(!q.empty())
{
int u=q.front(); q.pop();
inq[u]=false;
for(int v=; v<=n+m+; v++) if(cap[u][v]>flow[u][v]&&d[v]>d[u]+cost1[u][v])
{
d[v]=d[u]+cost1[u][v];
p[v]=u;
if(!inq[v])
{
inq[v]=true;
q.push(v);
}
}
}
if(d[t]==inf) break;
int a=inf;
for(int u=t; u!=s; u=p[u])
{
if(cap[p[u]][u]-flow[p[u]][u]<a)
{
a=cap[p[u]][u]-flow[p[u]][u];
}
}
for(int u=t; u!=s; u=p[u])
{
flow[p[u]][u]+=a;
flow[u][p[u]]-=a;
}
mm+=d[t]*a;
}
for(int j=; j<=n; j++)
{
if(flow[j+m][t]!=cap[j+m][t])
{
flag=false;
break;
}
}
if(!flag) break;
if(flag) tt+=mm;
}
if(flag) printf("%d\n",tt);
else printf("-1\n");
}
return ;
}

poj 2516Minimum Cost的更多相关文章

  1. POJ 2516Minimum Cost(最小费用流+特判)

    [题意]: 有N个人,M个仓库,每个人需要物品,个数都等于共同的K,仓库中有对应的K件物品的数量,随后给K个N*M矩阵(小写k, n, m表示K,N,M对应的子集),表明m个仓库到第n个人的位置运送k ...

  2. POJ 2516 Minimum Cost (网络流,最小费用流)

    POJ 2516 Minimum Cost (网络流,最小费用流) Description Dearboy, a goods victualer, now comes to a big problem ...

  3. POJ 2516 Minimum Cost(拆点+KM完备匹配)

    题目链接:http://poj.org/problem?id=2516 题目大意: 第一行是N,M,K 接下来N行:第i行有K个数字表示第i个卖场对K种商品的需求情况 接下来M行:第j行有K个数字表示 ...

  4. Poj 2516 Minimum Cost (最小花费最大流)

    题目链接: Poj  2516  Minimum Cost 题目描述: 有n个商店,m个仓储,每个商店和仓库都有k种货物.嘛!现在n个商店要开始向m个仓库发出订单了,订单信息为当前商店对每种货物的需求 ...

  5. POJ 2516 Minimum Cost (最小费用最大流)

    POJ 2516 Minimum Cost 链接:http://poj.org/problem?id=2516 题意:有M个仓库.N个商人.K种物品.先输入N,M.K.然后输入N行K个数,每一行代表一 ...

  6. POJ - 2516 Minimum Cost 每次要跑K次费用流

    传送门:poj.org/problem?id=2516 题意: 有m个仓库,n个买家,k个商品,每个仓库运送不同商品到不同买家的路费是不同的.问为了满足不同买家的订单的最小的花费. 思路: 设立一个源 ...

  7. POJ 2516:Minimum Cost(最小费用流)

    https://vjudge.net/problem/11079/origin 题意:有N个商店和M个供应商和K种物品,每个商店每种物品有一个需求数,每个供应商每种物品有一个供应量,供应商到商店之间的 ...

  8. POJ 2516 Minimum Cost [最小费用最大流]

    题意略: 思路: 这题比较坑的地方是把每种货物单独建图分开算就ok了. #include<stdio.h> #include<queue> #define MAXN 500 # ...

  9. POJ 2516 Minimum Cost 最小费用流

    题目: 给出n*kk的矩阵,格子a[i][k]表示第i个客户需要第k种货物a[i][k]单位. 给出m*kk的矩阵,格子b[j][k]表示第j个供应商可以提供第k种货物b[j][k]单位. 再给出k个 ...

随机推荐

  1. mysql 循环插入100w

    use md5db; DROP PROCEDURE if exists myFunction; delimiter $$ CREATE PROCEDURE myFunction() BEGIN DEC ...

  2. 2016最新cocoapods版本更新,以及多个版本的问题

    先删除之前的pod 在终端中执行下面命令. 删除目录下的podrm -rf /usr/local/bin/pod 执行gem list | grep cocoapods 查看所有与cocoapods相 ...

  3. spring注入成员对象

    就是将对象注入到另外一个对象中.这个样例就是有一个学校类,学校类中有一个校长类,最后使用測试文件输出学校类中的信息. 代码结构 学校类 package com.test.SpringGetSet; p ...

  4. COGS 859. 数列

    /* 先来说一下第一眼看到想出的奇葩方法23333.. 找每个数左右有几个比他小的 前几天刚学了区间第k小的求法 然后... 枚举中间的那个点 对于左区间 二分找到他是第几大 右区间同理 然后 *起来 ...

  5. uva 1391 Astronauts(2-SAT)

    /*翻译好题意 n个变量 不超过m*2句话*/ #include<iostream> #include<cstdio> #include<cstring> #inc ...

  6. HTML (1)href与Action,get post

    1.   href与Action的区别 href只能get参数,action能get参数又能post参数 href一般用于单个连接,可以带参数(URL重写),是采用get方式请求的,在地址栏中可以看到 ...

  7. datediff(),dateadd(),datepart().datename()时间处理函数

    原文链接:http://www.cnblogs.com/whz111/articles/2445777.html --convert(时间)对应数字表示的时间格式 select CONVERT(var ...

  8. ICOMOON!强悍的WEB字体图标制造器/Web字体使用实例

    IcoMoon!一个可以通过个性化设置来创建自定义图标(字体)的生成器!也可以将SVG图片,转换成web字体 IcoMoon是一项免费的服务,通过使用不同设置使我们能够创建自定义的ICON图或ICON ...

  9. Dedecms当前位置{dede:field name='position'/}修改

    这个实在list_article.htm模板出现的,而这个模板通过loadtemplage等等一系列操作是调用的include 下的arc.archives.class.php $this->F ...

  10. DataTable去重复方法

    //去掉重复行 DataTable table=new DataTable(); DataView dv = table.DefaultView; table = dv.ToTable(true, n ...