题目链接:https://vjudge.net/problem/POJ-2516

思路:对于每种商品跑最小费用最大流,如果所有商品和人一起建图跑,O(v^2*m)数量级太大,会超时。

把店里的商品拆点,入和出之间是商品库存量,起到限流作用。

源点->人对该商品的需求->库存点入->库存点出->汇点

源点与人之间的边的流为人的需求量,人对商品之间的边的流INF。

源点与人的边设置费用,其他边费用0.

#include <iostream>
#include <cstdio>
#include <algorithm>
#include <cstring>
#include <queue>
using namespace std; const int N = ,INF = (int)1e9;
int n,m,k,tot;
int head[N<<],pre[N<<],d[N<<],vis[N<<];
int p[N][N],g[N][N],c[N][N][N];
struct node{
int to,nxt,cap,flow,cost;
}e[N*N]; inline void add(int u,int v,int cap,int flow,int cost){
e[tot].to = v; e[tot].cap = cap; e[tot].flow = flow;
e[tot].cost = cost; e[tot].nxt = head[u]; head[u] = tot++; e[tot].to = u; e[tot].cap = ; e[tot].flow = flow;
e[tot].cost = -cost; e[tot].nxt = head[v]; head[v] = tot++;
} void input(int& sum_need){
sum_need = ;
for(int i = ; i <= n; ++i){
for(int j = ; j <= k; ++j){
scanf("%d",&p[i][j]);
sum_need += p[i][j];
}
}
for(int i = ; i <= m; ++i){
for(int j = ; j <= k; ++j)
scanf("%d",&g[i][j]);
}
for(int o = ; o <= k; ++o){
for(int i = ; i <= n; ++i){
for(int j = ; j <= m; ++j)
scanf("%d",&c[o][i][j]);
}
}
} void build_map(int o,int s,int t){
//0源点 1~n人 n+1~n+m 库存点入,
//n+m+1~n+2*m库存点出 n+2*m+1汇点。
for(int i = ; i <= n; ++i){
for(int j = ; j <= m; ++j){
add(i,j+n,INF,,c[o][i][j]);
}
}
for(int i = ; i <= n; ++i){
add(s,i,p[i][o],,);
}
for(int i = ; i <= m; ++i){
add(i+n,i+n+m,g[i][o],,);
add(i+n+m,t,INF,,);
}
} bool spfa(int s,int t){
for(int i = s; i <= t; ++i){
d[i] = INF; pre[i] = -; vis[i] = false;
}
queue<int > que;
que.push(s); d[s] = ; vis[s] = true;
while(!que.empty()){
int now = que.front(); que.pop();
vis[now] = false;
for(int o = head[now]; ~o; o = e[o].nxt){
int to = e[o].to;
if(e[o].cap > e[o].flow && d[to] > d[now] + e[o].cost){
d[to] = d[now] + e[o].cost;
pre[to] = o;
if(!vis[to]){
vis[to] = true;
que.push(to);
}
}
}
}
if(pre[t] == -) return false;
else return true;
} int mcmf(int s,int t,int& mf){ int Min = INF,mc = ;
while(spfa(s,t)){
Min = INF;
for(int o = pre[t]; ~o; o = pre[e[o^].to]){
Min = min(Min,e[o].cap - e[o].flow);
}
for(int o = pre[t]; ~o; o = pre[e[o^].to]){
e[o].flow += Min;
e[o^].flow -= Min;
}
mf += Min;
mc += d[t]*Min;
}
return mc;
} void init_main(){
memset(p,,sizeof(p));
memset(g,,sizeof(g));
memset(c,,sizeof(c));
} int main(){ int s,t,mc,mf,sum_need;//商品总需求量
while(~scanf("%d%d%d",&n,&m,&k) && (n+m+k)){
init_main();
input(sum_need);
s = ; t = n + *m + ;
mc = mf = ;
for(int o = ; o <= k; ++o){//第o种商品
for(int i = s; i <= t; ++i) head[i] = -; tot = ;
build_map(o,s,t);
mc += mcmf(s,t,mf);
}
//if(mf == sum_need) printf("-------------%d\n",mc);
//else printf("--------------no\n");
if(mf == sum_need) printf("%d\n",mc);
else printf("-1\n");
} return ;
}

kuangbin专题专题十一 网络流 Minimum Cost POJ - 2516的更多相关文章

  1. E - Minimum Cost - POJ 2516(最小费)

    题目大意:N个客户,M个供货商,K种商品,现在知道每个客户对每种商品的需求量,也知道每个供货商每种商品的持有量,和供货商把一种商品运送到每个客户的单位花费.现在想知道如果能满足所有客户的最小花费是多少 ...

  2. Minimum Cost POJ - 2516(模板题。。没啥好说的。。)

    题意: 从发货地到商家 送货 求送货花费的最小费用... 有m个发货地,,,n个商家,,每个商家所需要的物品和物品的个数都不一样,,,每个发货地有的物品和物品的个数也不一样,,, 从不同的发货地到不同 ...

  3. Minimum Cost POJ - 2516 (模板题 spfa最小费用最大流)

    题意: 人回家,一步一块钱,有x个人,y个房子,求能回家的最大人数且使之费用最小 解析: 就是....套模板,,,, 建图(⊙﹏⊙)...要仔细观察呐 对于人拆不拆都可以  都能过,,,,这里贴上拆开 ...

  4. kuangbin专题专题十一 网络流 Going Home POJ - 2195

    题目链接:https://vjudge.net/problem/POJ-2195 思路:曼哈顿距离来求每个人到每个房间的距离,把距离当作费用. 就可以用最小费用最大流来解决了,把每个房子拆成两个点,限 ...

  5. [kuangbin带你飞]专题十一 网络流

            ID Origin Title   34 / 81 Problem A POJ 3436 ACM Computer Factory   92 / 195 Problem B POJ 3 ...

  6. Kuangbin 带你飞专题十一 网络流题解 及模版 及上下界网络流等问题

    首先是几份模版 最大流:虽然EK很慢但是优势就是短.求最小割的时候可以根据增广时的a数组来判断哪些边是割边.然而SAP的最大流版我只会套版,并不知道该如何找到这个割边.在尝试的时候发现了一些问题.所以 ...

  7. [kuangbin带你飞]专题十一 网络流个人题解(L题留坑)

    A - ACM Computer Factory 题目描述:某个工厂可以利用P个部件做一台电脑,有N个加工用的机器,但是每一个机器需要特定的部分才能加工,给你P与N,然后是N行描述机器的最大同时加工数 ...

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

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

  9. Leetcode之动态规划(DP)专题-详解983. 最低票价(Minimum Cost For Tickets)

    Leetcode之动态规划(DP)专题-983. 最低票价(Minimum Cost For Tickets) 在一个火车旅行很受欢迎的国度,你提前一年计划了一些火车旅行.在接下来的一年里,你要旅行的 ...

随机推荐

  1. 珠峰-node

    ##### 文件流的读写. ##### 文件流对pipe的封装. ####

  2. java 开发社区蔬菜、食品交易平台系统 源码

    开发环境:    Windows操作系统开发工具: MyEclipse+Jdk+Tomcat+Mysql数据库 运行效果图 源码及原文链接:https://javadao.xyz/forum.php? ...

  3. Android中通过ImageSwitcher实现相册滑动查看照片功能(附代码下载)

    场景 效果 注: 博客: https://blog.csdn.net/badao_liumang_qizhi关注公众号 霸道的程序猿 获取编程相关电子书.教程推送与免费下载. 实现 将需要滚动查看的照 ...

  4. linux下(centos7)docker安装

    参考链接https://docs.docker.com/install/linux/docker-ce/centos/ 第一步,确定是centos7及以上版本 cat /etc/redhat-rele ...

  5. 浅谈background的用法

    div css 背景样式background属性 一.语法及参数 1.语法:background : background-color(颜色) || background-image(图片地址) || ...

  6. 《Adaptive Density Map Generation for Crowd Counting》密集人群检测论文笔记

    背景 密度图\(D_g\)的生成对于最终网络预测结果\(D_e\)至关重要,但是密度图\(D_g\)生成的过程中,高斯核的大小常常是手动设定的,并且对于不同的数据集,核大小和形状通常不一样.这些手动选 ...

  7. 利用 serviceStack 搭建web服务器

    1,资料地址 参考资料 https://docs.servicestack.net/ https://docs.servicestack.net/create-your-first-webservic ...

  8. Django复制记录的方法

    最近的Django项目中有复制记录的需求.数据库里有一张名为Party的表,记录用户创建的party,现在要让用户能够复制一个新的party.本身非常简单的一个功能,但运行的时候出错了.我以为是复制过 ...

  9. 【MVC+EasyUI实例】对数据网格的增删改查(上)

    前言 此案例是针对之前做的一个小例子的后台框架的修改,从以前的三层框架改为现在的MVC框架,也是做了一次MVC和EasyUI的结合,分为2篇文章来阐述. 界面如下: 点击"添加"按 ...

  10. cisco 添加静态路由

    静态路由:由人,手动写出的路由条目就叫静态路由,永久有效,优先级最高,效率最高. 路由器是干啥的? 连接不同地址段的网络.屏蔽不同地址段的网络广播. 路由器有多个接口,至少得有2个吧,一边一个局域网. ...