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

这题用矩阵存图,然后把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. (Struts2学习系列四)Struts2指定配置文件

    我们的每个action都在struts.xml里配置的话,就会出现很多的xml语句,单单一个struts.xml就会变得很大,所以我们会在struts.xml里使用include引入其他的.xml文件 ...

  2. 微信小程序picker下拉绑定数据

    页面部分 <picker mode = "selector" bindchange="bindPickerChange" value="{{pr ...

  3. u-boot 移植工作目录

    1. 添加工作用户 [root@localhost ~]#useradd -G root -g root -d/home/uboot uboot 2. 建立工作目录 [uboot@localhost ...

  4. unicode_start - 将控制台设为Unicode模式.

    总览 unicode_start [ font [ screen-font-map ] ] 描述 unicode_start 命令将显示屏及键盘设为 Unicode 模式, 并且有可能还会装载所用的 ...

  5. 批量Ping执行Bash脚本

    #!/bin/bash # Ping Batch Script # 连接超时时间 TMOUT= # 最大线程数 MAX_THREAD= # 保留内存大小 MIN_MEM= # 默认ip配置,可通过 - ...

  6. Python加密模块

    RSA加密 # 生成公钥私钥对象 import rsa pub_key_obj, priv_key_obj = rsa.newkeys(1024) ''' 这里的1024是二进制位数, 也就是说他加密 ...

  7. Go 关系运算符

    Go 关系运算符 package main import "fmt" func main() { var a int = 21 var b int = 10 if( a == b ...

  8. C++11中的技术剖析(萃取技术)

    从C++98开始萃取在泛型编程中用的特别多,最经典的莫过于STL.STL中的拷贝首先通过萃取技术识别是否是已知并且支持memcpy类型,如果是则直接通过内存拷贝提高效率,否则就通过类的重载=运算符,相 ...

  9. NX二次开发-UFUN打开选择文件夹对话框UF_UI_create_filebox

    #include <uf.h> #include <uf_ui.h> #include <string> using namespace std; string O ...

  10. NX二次开发-UFUN由工程图视图tag获取图纸页tag UF_DRAW_ask_drawing_of_view

    #include <uf.h> #include <uf_draw.h> #include <uf_drf.h> #include <uf_obj.h> ...