poj 2516Minimum Cost
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的更多相关文章
- POJ 2516Minimum Cost(最小费用流+特判)
[题意]: 有N个人,M个仓库,每个人需要物品,个数都等于共同的K,仓库中有对应的K件物品的数量,随后给K个N*M矩阵(小写k, n, m表示K,N,M对应的子集),表明m个仓库到第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(拆点+KM完备匹配)
题目链接:http://poj.org/problem?id=2516 题目大意: 第一行是N,M,K 接下来N行:第i行有K个数字表示第i个卖场对K种商品的需求情况 接下来M行:第j行有K个数字表示 ...
- Poj 2516 Minimum Cost (最小花费最大流)
题目链接: Poj 2516 Minimum Cost 题目描述: 有n个商店,m个仓储,每个商店和仓库都有k种货物.嘛!现在n个商店要开始向m个仓库发出订单了,订单信息为当前商店对每种货物的需求 ...
- 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 每次要跑K次费用流
传送门:poj.org/problem?id=2516 题意: 有m个仓库,n个买家,k个商品,每个仓库运送不同商品到不同买家的路费是不同的.问为了满足不同买家的订单的最小的花费. 思路: 设立一个源 ...
- POJ 2516:Minimum Cost(最小费用流)
https://vjudge.net/problem/11079/origin 题意:有N个商店和M个供应商和K种物品,每个商店每种物品有一个需求数,每个供应商每种物品有一个供应量,供应商到商店之间的 ...
- POJ 2516 Minimum Cost [最小费用最大流]
题意略: 思路: 这题比较坑的地方是把每种货物单独建图分开算就ok了. #include<stdio.h> #include<queue> #define MAXN 500 # ...
- 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个 ...
随机推荐
- Linux Epoll介绍和程序实例
Linux Epoll介绍和程序实例 1. Epoll是何方神圣? Epoll但是当前在Linux下开发大规模并发网络程序的热门人选,Epoll 在Linux2.6内核中正式引入,和select类似, ...
- Gridview实现银行选择列表
[MainActivity.java] package com.example.activitydemo; import android.os.Bundle; import android.view. ...
- c - static 变量
static变量和普通的局部变量不同,位于数据区中,在函数的外部初始化. ref: http://www.cnblogs.com/hustcat/archive/2009/06/30/1513755. ...
- linux command cp.
Examples cp file1.txt newdir Copies the file1.txt in the current directory to the newdir subdirector ...
- SQL Server 2008中数据压缩
SQL Server 2008中引入了数据压缩的功能,允许在表.索引和分区中执行数据压缩.这样不仅可以大大节省磁盘的占用空间,还允许将更多数据页装入内存中,从而降低磁盘IO,提升查询的性能.当然,凡事 ...
- MySQL 创建数据库
MySQL 创建数据库 使用 mysqladmin 创建数据库 使用普通用户,你可能需要特定的权限来创建或者删除 MySQL 数据库. 所以我们这边使用root用户登录,root用户拥有最高权限,可以 ...
- Asp.Net 母版页
背景:回顾下以前用到过的asp.net控件 介绍: 使用 ASP.NET 母版页可以为应用程序中的页创建一致的布局.单个母版页可以为应用程序中的所有页(或一组页)定义所需的外观和标准行为.然后可以创建 ...
- BOM和DOM详解
DOM介绍 D(文档)可以理解为整个Web加载的网页文档,O(对象)可以理解为类似window对象只来的东西,可以调用属性和方法,这里我们说的是document对象,M(模型)可以理解为网页文档的树形 ...
- web开发 关于src跳转
src跳转看传递的参数值,如果参数值一样就不会再次跳转,也不会向后台的服务器提供request. 想要随时都能跳转可以传递不同的参数,如 onClick="this.src='http:// ...
- 【转】lua random()
先来看看这两段代码: ① math.randomseed(os.time())for i=1,10 do n = math.random(10) print(n) 运行结果是: 63210754341 ...