网络流的题好难。。感觉有点遭不住了

这题用矩阵存图,然后把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的更多相关文章

  1. Spark Streaming源码解读之流数据不断接收全生命周期彻底研究和思考

    本期内容 : 数据接收架构设计模式 数据接收源码彻底研究 一.Spark Streaming数据接收设计模式   Spark Streaming接收数据也相似MVC架构: 1. Mode相当于Rece ...

  2. 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 ...

  3. .27-浅析webpack源码之事件流make(2)

    上一节跑到了NormalModuleFactory模块,调用了原型方法create后,依次触发了before-rsolve.factory.resolver事件流,这节从resolver事件流开始讲. ...

  4. .26-浅析webpack源码之事件流make(1)

    compilation事件流中,依然只是针对细节步骤做事件流注入,代码流程如图: // apply => this-compilation // apply => compilation ...

  5. .24-浅析webpack源码之事件流compilation(2)

    下一个compilation来源于以下代码: compiler.apply(new EntryOptionPlugin()); compiler.applyPluginsBailResult(&quo ...

  6. .23-浅析webpack源码之事件流compilation(1)

    正式开始跑编译,依次解析,首先是: compiler.apply( new JsonpTemplatePlugin(options.output), // start new FunctionModu ...

  7. .22-浅析webpack源码之事件流compilation总览

    呃,终于到了这地方-- newCompilation(params) { // ... this.applyPlugins("this-compilation", compilat ...

  8. .21-浅析webpack源码之事件流this-compilation

    上一节生成Compilation实例后,添加了一些属性,随后触发this-compilation事件流,如下: Compiler.prototype.newCompilation = (params) ...

  9. .34-浅析webpack源码之事件流make(3)

    新年好呀~过个年光打游戏,function都写不顺溜了. 上一节的代码到这里了: // NormalModuleFactory的resolver事件流 this.plugin("resolv ...

随机推荐

  1. 关于while循环中的break和continue的区别

    while循环如果不加条件限制的话,它会一直循环下去,那么问题就来了,如果我不用条件去终止while循环的话,那么我该用什么方法去终止呢? 你可以选择两种终止while循环的方法 1.break  强 ...

  2. 【持续更新】leetcode算法-数组篇

    会在近期陆续地完成数组篇的整理,希望对找工作的小伙伴有所帮助.   1.Two Sum:两数相加为一固定值,求其下标.一次遍历数组,用一个hash表存储已经访问过的数及其下标,对于新访问的数value ...

  3. 带你彻底理解RSA算法原理,很简单的

    1. 什么是RSA RSA算法是现今使用最广泛的公钥密码算法,也是号称地球上最安全的加密算法. 在了解RSA算法之前,先熟悉下几个术语 根据密钥的使用方法,可以将密码分为 对称密码 和 公钥密码 对称 ...

  4. HttpUrlConnection类基本使用

    这个类用来模拟浏览器向服务器发送请求和接收响应 注意: HttpUrlConnection对象简称huc对象 1)获取huc对象向url构造中传递url字符串,并调用openconnection方法即 ...

  5. SQL Server 中根据字段值查询其所在的表、字段

    DECLARE @what varchar(800)SET @what='123456' --要搜索的字符串   DECLARE @sql varchar(8000)   DECLARE TableC ...

  6. [原创] delphi Memo 滚动到底部/开始 [Delphi XE、Delphi 7]

    以前控制Memo滚动到底部的操作: SendMessage(memo1.Handle,WM_VSCROLL,SB_BOTTOM,0); 或者 Memo1.SelLength:=Length(Memo1 ...

  7. 代码格式化工具---prettier配置

    我自己的常用 prettier 配置如下: // .prettierrc 文件 // 这里修改的都是与默认值不同的,没有修改到的就是启用默认值 // .prettierrc 文件是使用 json 格式 ...

  8. Delphi中关于菜单的几个技巧

    -- 1将菜单项移到菜单栏的最右边 在一些应用程序中,常把一些特殊的菜单项放在菜单栏的最右边(如WPS2000 中的"定制界面"菜单,一些应用程序的帮助菜单),这些菜单项放在菜单栏 ...

  9. 其它课程中的python---1、python基础

    其它课程中的python---1.python基础 一.总结 一句话总结: 可以先把视频平台搭起来,这样学习效率会高很多,而且有额外收益 1.python的优势有哪些? 一个广泛的标准库 扩展性:比如 ...

  10. Spring随笔-bean装配

    Spring提供了三种装配方式 1.XML文件进行显式装配 2.java中进行显示装配 3.自动化装配 1.自动化装配的两种实现方式 1.组件扫描:Spring会自动发现应用上下文中创建的bean 2 ...