P3381 【模板】最小费用最大流
题目描述
如题,给出一个网络图,以及其源点和汇点,每条边已知其最大流量和单位流量费用,求出其网络最大流和在最大流情况下的最小费用。
输入输出格式
输入格式:
第一行包含四个正整数N、M、S、T,分别表示点的个数、有向边的个数、源点序号、汇点序号。
接下来M行每行包含四个正整数ui、vi、wi、fi,表示第i条有向边从ui出发,到达vi,边权为wi(即该边最大流量为wi),单位流量的费用为fi。
输出格式:
一行,包含两个整数,依次为最大流量和在最大流量情况下的最小费用。
输入输出样例
4 5 4 3 4 2 30 2 4 3 20 3 2 3 20 1 2 1 30 9 1 3 40 5
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 【模板】最小费用最大流相关推荐
- 经典网络流题目模板(P3376 + P2756 + P3381 : 最大流 + 二分图匹配 + 最小费用最大流)...
题目来源 P3376 [模板]网络最大流 P2756 飞行员配对方案问题 P3381 [模板]最小费用最大流 最大流 最大流问题是网络流的经典类型之一,用处广泛,个人认为网络流问题最具特点的操作就是建 ...
- 有源汇上下界最小费用可行流 ---- P4043 [AHOI2014/JSOI2014]支线剧情(模板)
题目链接 题目大意: 解题思路: 有源汇上下界最小费用可行流模板题目来着 先建出一个有源汇上下界可行流的图,然后注意建图的时候要把每条边的下界的费用提前加到ans里面 然后再对图跑费用流,就是补齐费用 ...
- Doctor NiGONiGO’s multi-core CPU(最小费用最大流模板)
题目链接:http://acm.nyist.net/JudgeOnline/problem.php?pid=693 题意:有一个 k 核的处理器和 n 个工作,全部的工作都须要在一个核上处理一个单位的 ...
- 费用流:最大费用最大流和最小费用最大流(模板)
主要是思维建边,建有向边,然后跑模板就行了 可以解决KM算法所能解决的问题(完全取代) 可以解决非完备匹配问题中的最大权匹配和最小权匹配,分别对应着最大费用最大流和最小费用最大流 模板: 最大费用最大 ...
- 最大流、最小费用最大流【模板】
一下代码版权归:HIT xiaodai 最大流模板:(题目链接) #include <cstring> #include <algorithm> #include < ...
- 最小费用最大流 【模板】
如果理解了最大流连续增广路算法的思维, 理解这个算法还是很简单的. 结构体存储信息: 分别为边的起点.终点.容量.当前流量.费用.下一条边的编号. struct Edge {int from, to, ...
- 最大流 最小费用最大流模板
模板从 这里 搬运,链接博客还有很多网络流题集题解参考. 最大流模板 ( 可处理重边 ) const int maxn = 1e6 + 10; const int INF = 0x3f3f3f3 ...
- 乌鲁木齐网络赛J题(最小费用最大流模板)
ACM ICPC 乌鲁木齐网络赛 J. Our Journey of Dalian Ends 2017-09-09 17:24 243人阅读 评论(0) 收藏 举报 分类: 网络流(33) 版权声 ...
- 【最小费用可行流模板】
可能再也用不到了吧,今天整理电脑文件看到的,作为图论选手,留个纪念, //原图: 对于pi,拆点xi,yi s->S,[m,m],0 S->xi,[0,inf],0 yi->t,[0 ...
- 【图论】最小费用最大流(网络流进阶)
本文 前置基础:最大流问题(Dinic算法) && 单源最短路径(SPFA算法) 洛谷 P3381 [模板]最小费用最大流 所谓最小费用最大流,其实就是在最大流问题的基础上,再给边加上 ...
最新文章
- 机器学习入门(01)— 感知机概念、实现、局限性以及多层感知机
- kivy texture图片格式和opencv numpy图片格式互转
- KotlinPoet
- 汇智创科机器人_【汇智创科机器人招聘信息】-看准网
- python数据分析——如何用python连接远程数据库
- python 异常点检测 cook距离_DLI 精选课程 | 三种AI方法检测网络、业务或设备异常状况...
- 判断当前窗口是否是全屏的山寨版和官方版
- css多行文本溢出显示省略号(…)
- photoshop cs3 无法复制文字的解决方案
- iOS CoreData (二) 版本升级和数据库迁移
- Error:Execution failed for task ':app:lint'.
- GoPose人工智能运动分析软件
- 【常识】户型图要怎么看?买房时销售员不会说的注意事项
- 远程桌面连接,运维工程师-必备软件【MultiDesk】
- vscode c++ code runner 配置 opencv
- 网络安全-解密WinRAR捆绑恶意程序并自动上线MSF的原理
- H3C服务器出厂系统密码,H3C S3100交换机不知道密码如何恢复出厂设置
- win10 输入法禁用IME
- 虚拟机做dcs服务器,虚拟机技术的DCS仿真 - 机械设计 - 电子发烧友网
- ScePT: 为规划的场景一致和基于策略轨迹预测
热门文章
- 【安卓项目】—— 口算测试APP(教程源自B站)
- web报表工具FineReport常见的数据集报错错误代码和解释
- AS3多线程快速入门(一):Hello World[
- list(链表)容器
- ajax中get请求url传参数
- python如何在没有环境的电脑上执行_没安装python的电脑可以运行python写的程序吗 python语言编写的程...
- java hashset char_java集合之HashSet
- 人脸关键点:MTCNN-Joint Face Detection and Alignment using Multi-task Cascaded Convolutional Networks
- pytorch学习笔记(二十二):Pooling
- 数据结构实验 8.寻找中位数