Luogu--3381 【模板】最小费用最大流
题目链接 3381 【模板】最小费用最大流
手写堆版本 dijkstra 400+ms 看来优先队列的常数好大
#include<bits/stdc++.h>
using namespace std;
#define maxn 100001
#define inf 0x3f3f3f3f
#define pii pair<int,int >
inline int read()
{
;
char c=getchar();
;
; c=getchar();}
)+(x<<)+c-';c=getchar();}
return flag?-x:x;
}
struct ac{
int to,va,cos,nex;
}eg[maxn*];
struct wa{
int x,y;
wa(){}
wa(int a,int b){
x=a,y=b;
}
}aa[maxn*];
int head[maxn],dis[maxn],pre[maxn],flow[maxn],h[maxn];
bool fa[maxn];
,maxcost=,tot=,len=;
void init(){
tot=;
memset(eg,,sizeof(eg));
memset(head,-,sizeof(head));
memset(h,,sizeof(h));
memset(pre,,sizeof(pre));
}
bool dcmp(wa A,wa B){
;
;
}
void add(int v){
)return;
]))swap(aa[v],aa[v/]),add(v/);
}
void updata(int v){
>len)return;
==len)
{
],aa[v]))swap(aa[v],aa[v*]);
return;
}
])&&dcmp(aa[v],aa[v*+]))return;
],aa[v*+]))swap(aa[v],aa[v*]),updata(v*);
+]),updata(v*+);
}
void add_eg(int u,int to,int va,int cos){
eg[tot].va=va;
eg[tot].cos=cos;
eg[tot].to=to;
eg[tot].nex=head[u];
head[u]=tot++;
eg[tot].va=;
eg[tot].cos=-cos;
eg[tot].to=u;
eg[tot].nex=head[to];
head[to]=tot++;
}
bool dijstra(int s,int t){
memset(dis,inf,sizeof(dis));
dis[s]=;
flow[s]=inf;
aa[++len]=wa(,s);
while(len){
wa x=aa[];
swap(aa[],aa[len--]);
updata();
int u=x.y;
if(dis[x.y]<x.x) continue;
;j=eg[j].nex){
int v=eg[j].to;
int f=eg[j].cos;
&&dis[v]>dis[u]+f+h[u]-h[v]){
dis[v]=dis[u]+f+h[u]-h[v];
flow[v]=min(flow[u],eg[j].va);
pre[v]=j;
aa[++len]=wa(dis[v],v);
add(len);
}
}
}
;
;
}
void work(){
while(dijstra(s,t)){
int z=t;
while(z!=s){
int i=pre[z];
eg[i].va-=flow[t];
eg[i^].va+=flow[t];
z=eg[i^].to;
}
;j<=n;j++){
h[j]+=dis[j];
}
maxflow+=flow[t];
maxcost+=flow[t]*h[t];
}
}
int main(){
cin>>n>>m>>s>>t;
init();
;j<m;j++){
int x,y,a,b;
//scanf("%d%d%d%d",&x,&y,&a,&b);
x=read(); y=read();a=read();b=read();
add_eg(x,y,a,b);
}
work();
printf("%d %d\n",maxflow,maxcost);
}
dijkstra 可能因为常数比较大 t了一个点但是 开o2之后可以轻松水过
dijkstra 版本
#include<bits/stdc++.h>
using namespace std;
#define maxn 100001
#define inf 0x3f3f3f3f
#define pii pair<int,int >
int head[maxn],dis[maxn],pre[maxn],flow[maxn],h[maxn];
struct ac{
int to,va,cos,nex;
}eg[maxn];
,maxcost=,tot=;
void init(){
tot=;
memset(eg,,sizeof(eg));
memset(head,-,sizeof(head));
memset(h,,sizeof(h));
memset(pre,,sizeof(pre));
}
void add_eg(int u,int to,int va,int cos){
eg[tot].va=va;
eg[tot].cos=cos;
eg[tot].to=to;
eg[tot].nex=head[u];
head[u]=tot++;
eg[tot].va=;
eg[tot].cos=-cos;
eg[tot].to=u;
eg[tot].nex=head[to];
head[to]=tot++;
}
bool dijstra(int s,int t){
memset(dis,inf,sizeof(dis));
memset(fa,,sizeof(fa));
dis[s]=;
flow[s]=inf;
fa[s]=;
priority_queue<pii,vector<pii>,greater<pii> >q;
q.push(make_pair(,s));
while(!q.empty()){
pii x=q.top();
q.pop();
int u=x.second;
if(dis[x.second]<x.first) continue;
;j=eg[j].nex){
int v=eg[j].to;
int f=eg[j].cos;
&&dis[v]>dis[u]+f+h[u]-h[v]){
dis[v]=dis[u]+f+h[u]-h[v];
flow[v]=min(flow[u],eg[j].va);
pre[v]=j;
q.push(make_pair(dis[v],v));
}
}
}
;
;
}
void work(){
while(dijstra(s,t)){
int z=t;
while(z!=s){
int i=pre[z];
eg[i].va-=flow[t];
eg[i^].va+=flow[t];
z=eg[i^].to;
}
;j<=n;j++){
h[j]+=dis[j];
}
maxflow+=flow[t];
maxcost+=flow[t]*h[t];
}
}
int main(){
cin>>n>>m>>s>>t;
init();
;j<m;j++){
int x,y,a,b;
scanf("%d%d%d%d",&x,&y,&a,&b);
add_eg(x,y,a,b);
}
work();
cout<<maxflow<<" "<<maxcost<<endl;
}
SPFA版本
// luogu-judger-enable-o2
#include<bits/stdc++.h>
using namespace std;
#define maxn 100001
#define inf 0x3f3f3f3f
int head[maxn],dis[maxn],pre[maxn],flow[maxn];
bool fa[maxn];
struct ac{
int to,va,cos,nex;
}eg[maxn*];
,maxcost=,tot=;
void init(){
tot=;
memset(eg,,sizeof(eg));
memset(head,-,sizeof(head));
}
void add_eg(int u,int to,int va,int cos){
eg[tot].va=va;
eg[tot].cos=cos;
eg[tot].to=to;
eg[tot].nex=head[u];
head[u]=tot++;
eg[tot].va=;
eg[tot].cos=-cos;
eg[tot].to=u;
eg[tot].nex=head[to];
head[to]=tot++;
}
bool spfa(int s,int t){
memset(dis,inf,sizeof(dis));
memset(fa,,sizeof(fa));
dis[s]=;
flow[s]=inf;
fa[s]=;
queue<int>q;
q.push(s);
while(!q.empty()){
int u=q.front();
q.pop();
fa[u]=;
;j=eg[j].nex){
int v=eg[j].to;
int f=eg[j].cos;
//cout<<u<<" "<<v<<endl;
if(eg[j].va&&dis[u]+f<dis[v]){
dis[v]=dis[u]+f;
flow[v]=min(flow[u],eg[j].va);
pre[v]=j;
if(!fa[v]){
fa[v]=;
q.push(v);
}
}
}
}
;
;
}
void work(){
while(spfa(s,t)){
int z=t;
while(z!=s){
int i=pre[z];
eg[i].va-=flow[t];
eg[i^].va+=flow[t];
z=eg[i^].to;
}
maxflow+=flow[t];
maxcost+=flow[t]*dis[t];
}
}
int main(){
cin>>n>>m>>s>>t;
init();
;j<m;j++){
int x,y,a,b;
cin>>x>>y>>a>>b;
add_eg(x,y,a,b);
}
work();
cout<<maxflow<<" "<<maxcost<<endl;
}
Luogu--3381 【模板】最小费用最大流的更多相关文章
- 洛谷.3381.[模板]最小费用最大流(zkw)
题目链接 Update:我好像刚知道多路增广就是zkw费用流.. //1314ms 2.66MB 本题优化明显 #include <queue> #include <cstdio&g ...
- 【Luogu】P3381最小费用最大流模板(SPFA找增广路)
题目链接 哈 学会最小费用最大流啦 思路是这样. 首先我们有一个贪心策略.如果我们每次找到单位费用和最短的一条增广路,那么显然我们可以把这条路添加到已有的流量里去——不管这条路的流量是多大,反正它能 ...
- 【洛谷 p3381】模板-最小费用最大流(图论)
题目:给出一个网络图,以及其源点和汇点,每条边已知其最大流量和单位流量费用,求出其网络最大流和在最大流情况下的最小费用. 解法:在Dinic的基础下做spfa算法. 1 #include<cst ...
- P3381 [模板] 最小费用最大流
EK + dijkstra (2246ms) 开氧气(586ms) dijkstra的势 可以处理负权 https://www.luogu.org/blog/28007/solution-p3381 ...
- Luogu P3381 (模板题) 最小费用最大流
<题目链接> 题目大意: 给定一张图,给定条边的容量和单位流量费用,并且给定源点和汇点.问你从源点到汇点的最带流和在流量最大的情况下的最小费用. 解题分析: 最小费用最大流果题. 下面的是 ...
- 费用流+SPFA ||Luogu P3381【模板】最小费用最大流
题面:[模板]最小费用最大流 代码: #include<cstdio> #include<cstring> #include<iostream> #include& ...
- 最小费用最大流 学习笔记&&Luogu P3381 【模板】最小费用最大流
题目描述 给出一个网络图,以及其源点和汇点,每条边已知其最大流量和单位流量费用,求出其网络最大流和在最大流情况下的最小费用. 题目链接 思路 最大流是没有问题的,关键是同时保证最小费用,因此,就可以把 ...
- luogu 3376 最小费用最大流 模板
类似EK算法,只是将bfs改成spfa,求最小花费. 为什么可以呢,加入1-3-7是一条路,求出一个流量为40,那么40*f[1]+40*f[2]+40*f[3],f[1]是第一条路的单位费用,f[2 ...
- 洛谷P3381 最小费用最大流模板
https://www.luogu.org/problem/P3381 题目描述 如题,给出一个网络图,以及其源点和汇点,每条边已知其最大流量和单位流量费用,求出其网络最大流和在最大流情况下的最小费用 ...
随机推荐
- 6 基于Servlet 的分页
实现上图的分页功能,每页显示3条数据,每页显示3页供用户访问,点击左右双箭头时,可以跳转至上一个或者下一个大页,如点击右双箭头显示如下: 1 连接数据库的工具类 package com.latiny. ...
- [转帖]SAP一句话入门:Production Planning
SAP一句话入门:Production Planning http://blog.vsharing.com/MilesForce/A617692.html SAP是庞大的,模块是多多的,功能是强大的, ...
- [转帖]IP /TCP协议及握手过程和数据包格式中级详解
IP /TCP协议及握手过程和数据包格式中级详解 https://www.toutiao.com/a6665292902458982926/ 写的挺好的 其实 一直没闹明白 网络好 广播地址 还有 网 ...
- python爬虫之初始scrapy
简介: Scrapy是一个为了爬取网站数据,提取结构性数据而编写的应用框架. 可以应用在包括数据挖掘,信息处理或存储历史数据等一系列的程序中. 其最初是为了 页面抓取 (更确切来说, 网络抓取 )所设 ...
- Socket构造但不连接
Socket socket = new Socket(); SocketAddress address = new InetSocketAddress("localhost",80 ...
- git(命令行常用炒作)
Git常用操作 https://backlog.com/git-tutorial/cn/intro/intro1_1.html Git详解(思维导图) https://blog.csdn.net/hu ...
- 集合转数组的toArray()和toArray(T[] a)方法
参考:集合转数组的toArray()和toArray(T[] a)方法 1.ArrayList的toArray ArrayList提供了一个将List转为数组的一个非常方便的方法toArray.toA ...
- 让PC端页面在手机端显示缩小版的解决方法
做页面的时候我们做好pC端页面时,因编辑那边需求,在手机端页面也应该是缩小版,不能乱的.在网上找了各种解决方案,经实验,这种是可以的: 在head里边加上这两句meta <meta name= ...
- volatile和synchronized的区别
volatile和synchronized特点 首先需要理解线程安全的两个方面:执行控制和内存可见. 执行控制的目的是控制代码执行(顺序)及是否可以并发执行. 内存可见控制的是线程执行结果在内存中对其 ...
- Redis 禁用FLUSHALL FLUSHDB KEYS 命令
(error) ERR unknown command 'keys'问题解决(error) ERR unknown command 'FLUSHDB' 问题解决 背景 FLUSHALL FLUSH ...