多源多汇费用流——poj2516
网络流的题好难。。感觉有点遭不住了
这题用矩阵存图,然后把k个物品,每个物品都求一次费用流
/*
多源多汇的费用流
其实是k个费用流
*/
#include<bits/stdc++.h>
using namespace std;
#define inf 0x3f3f3f3f
#define maxn 205
struct Edge{int to,nxt,w,c;}e[maxn<<];
int head[maxn],tot,n,m,s,t;
void init(){}
void add(int u,int v,int w,int c){} int sum_need[maxn],sum_offer[maxn];
int offer[maxn][maxn],need[maxn][maxn],mp[maxn][maxn],cost[maxn][maxn],K,sum,pre[maxn]; int dis[maxn],vis[maxn];
int spfa(){
queue<int>q;
for(int i=;i<=t;i++){vis[i]=false;dis[i]=inf;} vis[s]=;dis[s]=;q.push(s);
while(!q.empty()){
int k=q.front();q.pop();vis[k]=false;
for(int i=;i<=t;i++)
if(mp[k][i] && dis[i]>dis[k]+cost[k][i]){
dis[i]=dis[k]+cost[k][i];
pre[i]=k;
if(!vis[i]){
vis[i]=;
q.push(i);
}
}
} if(dis[t]!=inf)return ;
return ;
}
int fond(){
int Min=inf,res=;
while(spfa()){
for(int i=t;i!=s;i=pre[i])
Min=min(Min,mp[pre[i]][i]);
for(int i=t;i!=s;i=pre[i]){
mp[pre[i]][i]-=Min;
mp[i][pre[i]]+=Min;
res+=cost[pre[i]][i]*Min;
}
}
return res;
} int main(){
while(cin>>n>>m>>K,n&&m&&K){
sum=;
memset(sum_need,,sizeof sum_need);
memset(sum_offer,,sizeof sum_offer); for(int i=;i<=n;i++)
for(int j=;j<=K;j++){
scanf("%d",&need[i][j]);
sum_need[j]+=need[i][j];
}
for(int i=;i<=m;i++)
for(int j=;j<=K;j++){
scanf("%d",&offer[i][j]);
sum_offer[j]+=offer[i][j];
}
int sign=;
for(int i=;i<=K;i++)
if(sum_offer[i]<sum_need[i]){
sign=;
break;
}
s=;
t=n+m+;
for(int k=;k<=K;k++){
memset(mp,,sizeof mp);
memset(cost,,sizeof cost);
//第k件物品 供应商->店主的运费
for(int i=+m;i<=n+m;i++)
for(int j=;j<=m;j++){
scanf("%d",&cost[j][i]);
cost[i][j]-=cost[j][i];//反向边的费用
} if(sign==)continue; for(int i=;i<=m;i++)//s->供应商
mp[s][i]=offer[i][k];
for(int i=;i<=m;i++)//供应商->店主
for(int j=m+;j<=m+n;j++)
mp[i][j]=offer[i][k];
for(int i=m+;i<=m+n;i++)//店主->t
mp[i][t]=need[i-m][k];
sum+=fond();
}
if(sign==)
printf("-1\n");
else printf("%d\n",sum);
}
}
多源多汇费用流——poj2516的更多相关文章
- Spark Streaming源码解读之流数据不断接收全生命周期彻底研究和思考
本期内容 : 数据接收架构设计模式 数据接收源码彻底研究 一.Spark Streaming数据接收设计模式 Spark Streaming接收数据也相似MVC架构: 1. Mode相当于Rece ...
- poj 1459 多源多汇点最大流
Sample Input 2 1 1 2 (0,1)20 (1,0)10 (0)15 (1)20 7 2 3 13 (0,0)1 (0,1)2 (0,2)5 (1,0)1 (1,2)8 (2,3)1 ...
- .27-浅析webpack源码之事件流make(2)
上一节跑到了NormalModuleFactory模块,调用了原型方法create后,依次触发了before-rsolve.factory.resolver事件流,这节从resolver事件流开始讲. ...
- .26-浅析webpack源码之事件流make(1)
compilation事件流中,依然只是针对细节步骤做事件流注入,代码流程如图: // apply => this-compilation // apply => compilation ...
- .24-浅析webpack源码之事件流compilation(2)
下一个compilation来源于以下代码: compiler.apply(new EntryOptionPlugin()); compiler.applyPluginsBailResult(&quo ...
- .23-浅析webpack源码之事件流compilation(1)
正式开始跑编译,依次解析,首先是: compiler.apply( new JsonpTemplatePlugin(options.output), // start new FunctionModu ...
- .22-浅析webpack源码之事件流compilation总览
呃,终于到了这地方-- newCompilation(params) { // ... this.applyPlugins("this-compilation", compilat ...
- .21-浅析webpack源码之事件流this-compilation
上一节生成Compilation实例后,添加了一些属性,随后触发this-compilation事件流,如下: Compiler.prototype.newCompilation = (params) ...
- .34-浅析webpack源码之事件流make(3)
新年好呀~过个年光打游戏,function都写不顺溜了. 上一节的代码到这里了: // NormalModuleFactory的resolver事件流 this.plugin("resolv ...
随机推荐
- 新项目UX设计0到1的正确开启方式
无论是在BAT还是创业小公司,都随时可能接到从0开始的新项目,那么作为负责新项目的主设OR独立设计师,我们应该从何开启工作呢?
- 微信小程序中实现左右滑动图片翻页
页面代码 <swiper class="container" indicator-dots="{{indicatordots}}" autoplay=&q ...
- 使用fastClick.js所产生的一些问题
开发h5活动页时想到移动端会有300ms的延迟,于是便打算用fastClick.js解决. 页面引入fastClick.js后,滑动H5页面的时候发现谷歌浏览器会报错,如下: Unable to pr ...
- 15_TLB中的G属性
> TLB 是为了增加访问内存的效率 即 如果 是 29 9 12 分页 请求数据 可能需要访问 4次内存:为了解决这个问题:出现了 TLB (虚拟地址到物理地址的转换关系),如果目标地址在TL ...
- 报错 DOMDocument not found
php -m 查看有没有dom扩展 没有安装扩展 yum install php-dom php 常用扩展有 yum install php-solr php-opcache php-seasLog ...
- leetcode-12周双周赛-5090-抛掷硬币
题目描述: 二维dp: class Solution: def probabilityOfHeads(self, prob: List[float], target: int) -> float ...
- thinkphp 快速缓存
如果你的存储数据没有有效期的需求,那么系统还提供了一个快速缓存方法F可以用来更快的操作. 大理石平台厂家 F方法可以支持不同的存储类型,如果是文件类型的话,默认保存在DATA_PATH目录下面. 快速 ...
- 归并排序c语言
void mergeAdd(int arr[], int left, int mid, int right, int *temp){ int i = left; ; int k = left;//临时 ...
- arcgis api for javascipt 输出图片
地图模板制作-发布-gpurl调用 window.open可以直接打开url链接. saveas可以另存,仅支持ie浏览器 <!DOCTYPE html><html><h ...
- 秦曾昌人工智能课程---6、Decision Tree Learning
秦曾昌人工智能课程---6.Decision Tree Learning 一.总结 一句话总结: 怎样去构建决策树:比如一维:***|00|***|000|***,|为分割线,每个分割点都是一种情况, ...