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

题意:有k种货物,n个客户对每种货物有一定需求量,有m个仓库。每一个仓库里有一定数量的k种货物。然后k个n*m的矩阵,告诉从各个仓库到各个客户位置运送单位第k种货物所需的运费。问满足全部客户需求的最小费用,如满足不了全部客户,则输出-1。

思路:题目有点绕。只是多看看也就理解了。这道题算是最小费用最大流的入门题吧,建图非常easy能想到,主要是存在k种货物。每条货物都要建一条路,同一时候处理起来不好写。并且路径也较多。只是能够对每种货物分开来算。数据比較小。给了4000ms,不会超时。对每一个n*m矩阵,对于此时的货物建图。把最小费用累加起来。

假设有一种货物没法满足全部客户。即网络最大流不等于客户需求之和,则输出-1。

建图:对于每种货物单独建图。一个超级源点连向每一个客户。弧为客户对当前这样的货物的需求量,权为0。每一个仓库连向超级汇点,弧为仓库中当前这样的货物的储存量,权为0。对于n*m的矩阵,相应的客户连向相应的仓库,弧为INF,权为运送单位货物的花费。

这样的建图方式比較好想,之前也做过几道题是一样的思路。

  1. #include<cstring>
  2. #include<string>
  3. #include<fstream>
  4. #include<iostream>
  5. #include<iomanip>
  6. #include<cstdio>
  7. #include<cctype>
  8. #include<algorithm>
  9. #include<queue>
  10. #include<map>
  11. #include<set>
  12. #include<vector>
  13. #include<stack>
  14. #include<ctime>
  15. #include<cstdlib>
  16. #include<functional>
  17. #include<cmath>
  18. using namespace std;
  19. #define PI acos(-1.0)
  20. #define MAXN 500100
  21. #define eps 1e-7
  22. #define INF 0x7FFFFFFF
  23. #define LLINF 0x7FFFFFFFFFFFFFFF
  24. #define seed 131
  25. #define mod 1000000007
  26. #define ll long long
  27. #define ull unsigned ll
  28. #define lson l,m,rt<<1
  29. #define rson m+1,r,rt<<1|1
  30.  
  31. struct node{
  32. int u,v,w,cost,next;
  33. }edge[MAXN];
  34. int head[150],dist[150],pree[150],vis[150];
  35. int n,m,k,cnt,src,sink,ans;
  36. void add_edge(int a,int b,int c,int d){
  37. edge[cnt].v = b;
  38. edge[cnt].w = c;
  39. edge[cnt].cost = d;
  40. edge[cnt].next = head[a];
  41. head[a] = cnt++;
  42. }
  43. bool spfa(){
  44. int i,j;
  45. queue<int>q;
  46. q.push(src);
  47. memset(vis,0,sizeof(vis));
  48. for(i=0;i<=n+m+2;i++) dist[i] = INF;
  49. dist[src] = 0;
  50. vis[src] = 1;
  51. while(!q.empty()){
  52. int u = q.front();
  53. q.pop();
  54. vis[u] = 0;
  55. for(i=head[u];i!=-1;i=edge[i].next){
  56. if(edge[i].w&&dist[u]!=INF&&dist[u]+edge[i].cost<dist[edge[i].v]){
  57. dist[edge[i].v] = dist[u] + edge[i].cost;
  58. pree[edge[i].v] = i;
  59. if(!vis[edge[i].v]){
  60. vis[edge[i].v] = 1;
  61. q.push(edge[i].v);
  62. }
  63. }
  64. }
  65. }
  66. // for(i=0;i<=n+m+2;i++){
  67. // cout<<dist[i]<<endl;
  68. // }
  69. // cout<<endl<<endl;
  70. if(dist[sink]<INF) return true;
  71. return false;
  72. }
  73. int augment(){
  74. int i,j;
  75. int delta = INF;
  76. for(i=sink;i!=src;i=edge[j^1].v){
  77. j = pree[i];
  78. delta = min(delta,edge[j].w);
  79. }
  80. for(i=sink;i!=src;i=edge[j^1].v){
  81. j = pree[i];
  82. edge[j].w -= delta;
  83. edge[j^1].w += delta;
  84. ans += edge[j].cost * delta;
  85. }
  86. return delta;
  87. }
  88.  
  89. int ntok[60][60],ktom[60][60];
  90. int main(){
  91. int i,j,k;
  92. int a,b,c,sum;
  93. while(scanf("%d%d%d",&n,&m,&k),n||m||k){
  94. ans = 0;
  95. for(i=1;i<=n;i++){
  96. for(j=1;j<=k;j++){
  97. scanf("%d",&ntok[i][j]);
  98. }
  99. }
  100. for(i=1;i<=m;i++){
  101. for(j=1;j<=k;j++){
  102. scanf("%d",&ktom[i][j]);
  103. }
  104. }
  105. src = n + m + 2;
  106. sink = n + m + 1;
  107. int ii;
  108. int flag = 0;
  109. for(i=1;i<=k;i++){
  110. memset(head,-1,sizeof(head));
  111. cnt = 0;
  112. sum = 0;
  113. int flow = 0;
  114. for(ii=1;ii<=n;ii++){
  115. for(j=1;j<=m;j++){
  116. scanf("%d",&a);
  117. add_edge(ii,j+n,INF,a);
  118. add_edge(j+n,ii,0,-a);
  119. }
  120. }
  121. if(flag) continue;
  122. for(ii=1;ii<=n;ii++){
  123. add_edge(src,ii,ntok[ii][i],0);
  124. add_edge(ii,src,0,0);
  125. sum += ntok[ii][i];
  126. }
  127. for(ii=1;ii<=m;ii++){
  128. add_edge(ii+n,sink,ktom[ii][i],0);
  129. add_edge(sink,ii+n,0,0);
  130. }
  131. while(spfa()){
  132. flow += augment();
  133. }
  134. if(flow!=sum) flag = 1;
  135. }
  136. if(flag) puts("-1");
  137. else printf("%d\n",ans);
  138. }
  139. return 0;
  140. }

POJ--2516--Minimum Cost【最小费用最大流】的更多相关文章

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

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

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

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

  3. POJ2516:Minimum Cost(最小费用最大流)

    Minimum Cost Time Limit: 4000MS   Memory Limit: 65536K Total Submissions: 19088   Accepted: 6740 题目链 ...

  4. POJ2516 Minimum Cost —— 最小费用最大流

    题目链接:https://vjudge.net/problem/POJ-2516 Minimum Cost Time Limit: 4000MS   Memory Limit: 65536K Tota ...

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

    Description Dearboy, a goods victualer, now comes to a big problem, and he needs your help. In his s ...

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

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

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

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

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

    1.K种物品,M个供应商,N个收购商.每种物品从一个供应商运送到一个收购商有一个单位运费.每个收购商都需要K种物品中的若干.求满足所有收购商需求的前提下的最小运费. 2.K种物品拆开来,分别对每种物品 ...

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

    Description Dearboy, a goods victualer, now comes to a big problem, and he needs your help. In his s ...

  10. POJ 2516 Minimum Cost

    每个物品分开做最小费用最大流. #include<cstdio> #include<cstring> #include<cmath> #include<vec ...

随机推荐

  1. 对比学习sass和stylus的常用功能

    在众多的css预处理器语言中,sass和stylus算是十分优秀的两个.本文主要针对两者的常用功能做个简单的对比分析.在对比中了解二者的差异,同时帮助大家更好的掌握这两种预处理语言.本文涉及到的sas ...

  2. 05-数据类型转换(bool转换)

    05-数据类型转换(bool转换)

  3. Java Web乱码分析及解决方式(二)——POST请求乱码

    引言 GET请求的本质表现是将请求參数放在URL地址栏中.form表单的Method为GET的情况.參数会被浏览器默认编码,所以乱码处理方案是一样的. 对于POST请求乱码.解决起来要比GET简单.我 ...

  4. cocos2d-x 3.1.1学习笔记[23]寻找主循环 mainloop

    文章出自于  http://blog.csdn.net/zhouyunxuan cocos2d到底是怎样把场景展示给我们的,我一直非常好奇. 凭个人猜想,引擎内部的结构类似于这样 while(true ...

  5. Codeforces 528A Glass Carving STL模拟

    题目链接:点击打开链接 题意: 给定n*m的矩阵.k个操作 2种操作: 1.H x 横向在x位置切一刀 2.V y 竖直在y位置切一刀 每次操作后输出最大的矩阵面积 思路: 由于行列是不相干的,所以仅 ...

  6. vue11 vue实例方法

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...

  7. Zookeeper的单节点集群详细启动步骤

    这个很简单,见如下博客. 1 week110的zookeeper的安装 + zookeeper提供少量数据的存储 [hadoop@weekend110 zookeeper-3.4.6]$ pwd/ho ...

  8. Active Object 并发模式在 Java 中的应用--转载

    原文地址:http://www.ibm.com/developerworks/cn/java/j-lo-activeobject/ 本文主要从以下两个方面进行阐述: 使用 C++ 语言,来描述 Act ...

  9. P1824 进击的奶牛

    题目描述 Farmer John建造了一个有N(2<=N<=100,000)个隔间的牛棚,这些隔间分布在一条直线上,坐标是x1,...,xN (0<=xi<=1,000,000 ...

  10. c#多线程操作测试(阻塞线程,结束任务)

    using System; using System.Collections.Generic; using System.ComponentModel; using System.Data; usin ...