题目描述

如题,给出一个网络图,以及其源点和汇点,每条边已知其最大流量和单位流量费用,求出其网络最大流和在最大流情况下的最小费用。

输入输出格式

输入格式:

第一行包含四个正整数N、M、S、T,分别表示点的个数、有向边的个数、源点序号、汇点序号。

接下来M行每行包含四个正整数ui、vi、wi、fi,表示第i条有向边从ui出发,到达vi,边权为wi(即该边最大流量为wi),单位流量的费用为fi。

输出格式:

一行,包含两个整数,依次为最大流量和在最大流量情况下的最小费用。

输入输出样例

输入样例#1:

4 5 4 3
4 2 30 2
4 3 20 3
2 3 20 1
2 1 30 9
1 3 40 5

输出样例#1:

50 280

说明

时空限制:1000ms,128M

(BYX:最后两个点改成了1200ms)

数据规模:

对于30%的数据:N<=10,M<=10

对于70%的数据:N<=1000,M<=1000

对于100%的数据:N<=5000,M<=50000

样例说明:

如图,最优方案如下:

第一条流为4-->3,流量为20,费用为3*20=60。

第二条流为4-->2-->3,流量为20,费用为(2+1)*20=60。

第三条流为4-->2-->1-->3,流量为10,费用为(2+9+5)*10=160。

故最大流量为50,在此状况下最小费用为60+60+160=280。

故输出50 280。

SPFA费用流的模板题,

用SPFA检查是否可以增广

  1 #include<iostream>
  2 #include<cstdio>
  3 #include<cstring>
  4 #include<cmath>
  5 #include<queue>
  6 using namespace std;
  7 const int MAXN=2000001;
  8 const int maxn=0x7fffffff;
  9 void read(int &n)
 10 {
 11     char c='+';int x=0;bool flag=0;
 12     while(c<'0'||c>'9'){c=getchar();if(c=='-')flag=1;}
 13     while(c>='0'&&c<='9'){x=x*10+(c-48);c=getchar();}
 14     flag==1?n=-x:n=x;
 15 }
 16 struct node
 17 {
 18     int u,v,flow,spend,nxt;
 19 }edge[MAXN];
 20 int head[MAXN];
 21 int num=0;
 22 int n,m,s,t;
 23 int ans=0,maxflow=0;
 24 int dis[MAXN];
 25 int vis[MAXN];
 26 int from[MAXN];
 27 void add_edge(int x,int y,int z,int c)
 28 {
 29     edge[num].u=x;
 30     edge[num].v=y;
 31     edge[num].flow=z;
 32     edge[num].spend=c;
 33     edge[num].nxt=head[x];
 34     head[x]=num++;
 35 }
 36 bool SPFA()
 37 {
 38     for(int i=1;i<=n;i++)
 39         dis[i]=maxn;
 40     memset(vis,0,sizeof(vis));
 41     dis[s]=0;
 42     queue<int>q;
 43     q.push(s);
 44     vis[s]=1;
 45     while(q.size()!=0)
 46     {
 47         int p=q.front();
 48         q.pop();
 49         vis[p]=0;
 50         for(int i=head[p];i!=-1;i=edge[i].nxt)
 51         {
 52             if(dis[edge[i].v]>dis[edge[i].u]+edge[i].spend&&edge[i].flow>0)
 53             {
 54                 dis[edge[i].v]=dis[edge[i].u]+edge[i].spend;
 55                 from[edge[i].v]=i;
 56                 if(!vis[edge[i].v])
 57                 {
 58                     vis[edge[i].v]=1;
 59                     q.push(edge[i].v);
 60                 }
 61             }
 62         }
 63     }
 64     if(dis[t]!=maxn)
 65         return 1;
 66     else
 67         return 0;
 68
 69 }
 70 void f()
 71 {
 72     int mn=maxn;
 73     for(int i=t;i!=s;i=edge[from[i]].u)
 74         mn=min(mn,edge[from[i]].flow);
 75     for(int i=t;i!=s;i=edge[from[i]].u)
 76     {
 77         edge[from[i]].flow-=mn;
 78         edge[from[i]^1].flow+=mn;
 79         ans+=(mn*edge[from[i]].spend);
 80     }
 81     maxflow+=mn;
 82 }
 83 int main()
 84 {
 85     read(n);read(m);read(s);read(t);
 86     //s=1;
 87     //t=n;
 88     memset(head,-1,sizeof(head));
 89     for(int i=1;i<=m;i++)
 90     {
 91         int x,y,z,c;
 92         read(x);read(y);read(z);read(c);
 93         add_edge(x,y,z,c);
 94         add_edge(y,x,0,-c);
 95     }
 96     while(SPFA())
 97         f();
 98     printf("%d %d",maxflow,ans);
 99     return 0;
100 }

转载于:https://www.cnblogs.com/zwfymqz/p/7252479.html

P3381 【模板】最小费用最大流相关推荐

  1. 经典网络流题目模板(P3376 + P2756 + P3381 : 最大流 + 二分图匹配 + 最小费用最大流)...

    题目来源 P3376 [模板]网络最大流 P2756 飞行员配对方案问题 P3381 [模板]最小费用最大流 最大流 最大流问题是网络流的经典类型之一,用处广泛,个人认为网络流问题最具特点的操作就是建 ...

  2. 有源汇上下界最小费用可行流 ---- P4043 [AHOI2014/JSOI2014]支线剧情(模板)

    题目链接 题目大意: 解题思路: 有源汇上下界最小费用可行流模板题目来着 先建出一个有源汇上下界可行流的图,然后注意建图的时候要把每条边的下界的费用提前加到ans里面 然后再对图跑费用流,就是补齐费用 ...

  3. Doctor NiGONiGO’s multi-core CPU(最小费用最大流模板)

    题目链接:http://acm.nyist.net/JudgeOnline/problem.php?pid=693 题意:有一个 k 核的处理器和 n 个工作,全部的工作都须要在一个核上处理一个单位的 ...

  4. 费用流:最大费用最大流和最小费用最大流(模板)

    主要是思维建边,建有向边,然后跑模板就行了 可以解决KM算法所能解决的问题(完全取代) 可以解决非完备匹配问题中的最大权匹配和最小权匹配,分别对应着最大费用最大流和最小费用最大流 模板: 最大费用最大 ...

  5. 最大流、最小费用最大流【模板】

    一下代码版权归:HIT    xiaodai 最大流模板:(题目链接) #include <cstring> #include <algorithm> #include < ...

  6. 最小费用最大流 【模板】

    如果理解了最大流连续增广路算法的思维, 理解这个算法还是很简单的. 结构体存储信息: 分别为边的起点.终点.容量.当前流量.费用.下一条边的编号. struct Edge {int from, to, ...

  7. 最大流 最小费用最大流模板

    模板从  这里   搬运,链接博客还有很多网络流题集题解参考. 最大流模板 ( 可处理重边 ) const int maxn = 1e6 + 10; const int INF = 0x3f3f3f3 ...

  8. 乌鲁木齐网络赛J题(最小费用最大流模板)

    ACM ICPC 乌鲁木齐网络赛 J. Our Journey of Dalian Ends 2017-09-09 17:24 243人阅读 评论(0) 收藏 举报  分类: 网络流(33)  版权声 ...

  9. 【最小费用可行流模板】

    可能再也用不到了吧,今天整理电脑文件看到的,作为图论选手,留个纪念, //原图: 对于pi,拆点xi,yi s->S,[m,m],0 S->xi,[0,inf],0 yi->t,[0 ...

  10. 【图论】最小费用最大流(网络流进阶)

    本文 前置基础:最大流问题(Dinic算法) && 单源最短路径(SPFA算法) 洛谷 P3381 [模板]最小费用最大流 所谓最小费用最大流,其实就是在最大流问题的基础上,再给边加上 ...

最新文章

  1. 机器学习入门(01)— 感知机概念、实现、局限性以及多层感知机
  2. kivy texture图片格式和opencv numpy图片格式互转
  3. KotlinPoet
  4. 汇智创科机器人_【汇智创科机器人招聘信息】-看准网
  5. python数据分析——如何用python连接远程数据库
  6. python 异常点检测 cook距离_DLI 精选课程 | 三种AI方法检测网络、业务或设备异常状况...
  7. 判断当前窗口是否是全屏的山寨版和官方版
  8. css多行文本溢出显示省略号(…)
  9. photoshop cs3 无法复制文字的解决方案
  10. iOS CoreData (二) 版本升级和数据库迁移
  11. Error:Execution failed for task ':app:lint'.
  12. GoPose人工智能运动分析软件
  13. 【常识】户型图要怎么看?买房时销售员不会说的注意事项
  14. 远程桌面连接,运维工程师-必备软件【MultiDesk】
  15. vscode c++ code runner 配置 opencv
  16. 网络安全-解密WinRAR捆绑恶意程序并自动上线MSF的原理
  17. H3C服务器出厂系统密码,H3C S3100交换机不知道密码如何恢复出厂设置
  18. win10 输入法禁用IME
  19. 虚拟机做dcs服务器,虚拟机技术的DCS仿真 - 机械设计 - 电子发烧友网
  20. ScePT: 为规划的场景一致和基于策略轨迹预测

热门文章

  1. 【安卓项目】—— 口算测试APP(教程源自B站)
  2. web报表工具FineReport常见的数据集报错错误代码和解释
  3. AS3多线程快速入门(一):Hello World[
  4. list(链表)容器
  5. ajax中get请求url传参数
  6. python如何在没有环境的电脑上执行_没安装python的电脑可以运行python写的程序吗 python语言编写的程...
  7. java hashset char_java集合之HashSet
  8. 人脸关键点:MTCNN-Joint Face Detection and Alignment using Multi-task Cascaded Convolutional Networks
  9. pytorch学习笔记(二十二):Pooling
  10. 数据结构实验 8.寻找中位数