2018.08.20 loj#117. 有源汇有上下界最小流(模板)
传送门
这题真有意思。。。
先是有一个点T的我怀疑人生。
然后学大佬们封装了我的dinic就莫名其妙的过了???
所以说锅给谁好呢?
给dinic吧。。。
解法就是先求出一段可行流,然后从t到s加一条容量为inf的边将能缩回去的都缩回去。
代码:
#include<bits/stdc++.h>
#define ll long long
#define inf 0x3f3f3f3f
#define N 100005
#define M 2000010
using namespace std;
#define rep(i,st,ed) for(register int i=st,i##end=ed;i<=i##end;++i)
#define drep(i,st,ed) for(register int i=st,i##end=ed;i>=i##end;--i)
inline int read(){
int ans=0;
char ch=getchar();
while(!isdigit(ch))ch=getchar();
while(isdigit(ch))ans=(ans<<3)+(ans<<1)+(ch^48),ch=getchar();
return ans;
}
ll ans;
int S,T;
struct Node{int v,next,c;};
struct Max_Flow{
int n,cur[N],first[N],d[N],cnt;
Node e[M];
inline void add_edge(int u,int v,int c){e[++cnt].v=v,e[cnt].next=first[u],e[cnt].c=c,first[u]=cnt;}
inline void add(int u,int v,int c){add_edge(u,v,c),add_edge(v,u,0);}
inline bool bfs(){
rep(i,1,n)d[i]=-1;
queue<int>q;
q.push(S),d[S]=0;
while(!q.empty()){
int x=q.front();
q.pop();
for(int i=first[x];i;i=e[i].next){
int v=e[i].v;
if(e[i].c&&d[v]==-1){
d[v]=d[x]+1;
if(v==T)return true;
q.push(v);
}
}
}
return false;
}
inline int dfs(int x,int f){
if(x==T||!f)return f;
int flow=f,tmp;
for(int &i=cur[x];i;i=e[i].next){
int v=e[i].v;
if(e[i].c&&d[v]==d[x]+1){
tmp=dfs(v,min(e[i].c,flow));
if(!tmp)d[v]=-1;
e[i].c-=tmp,e[i^1].c+=tmp,flow-=tmp;
if(!flow)return f;
}
}
return f-flow;
}
inline void solve(){while(bfs()){rep(i,1,n)cur[i]=first[i];ans+=dfs(S,inf);}}
}Dinic;
int sum[N];
int main(){
Dinic.cnt=1;
int n=read(),m=read(),ss=read(),tt=read();
S=n+1,T=n+2,Dinic.n=T;
rep(i,1,m){
int u=read(),v=read(),down=read(),up=read();
sum[u]-=down,sum[v]+=down,Dinic.add(u,v,up-down);
}
rep(i,1,n){
if(sum[i]>0)Dinic.add(S,i,sum[i]);
if(sum[i]<0)ans+=sum[i],Dinic.add(i,T,-sum[i]);
}
Dinic.solve(),Dinic.add(tt,ss,inf),Dinic.solve();
if(ans){cout<<"please go home to sleep";return 0;}
cout<<Dinic.e[Dinic.cnt].c;
return 0;
}
2018.08.20 loj#117. 有源汇有上下界最小流(模板)的更多相关文章
- 2018.08.20 loj#116. 有源汇有上下界最大流(模板)
传送门 貌似就是转成无源汇,然后两遍最大流搞定? 其实第二遍跑最大流是自动加上了第一次的答案. 代码: #include<bits/stdc++.h> #define N 100005 # ...
- loj #117. 有源汇有上下界最小流
题目链接 有源汇有上下界最小流,->上下界网络流 注意细节,边数组也要算上后加到SS,TT边. #include<cstdio> #include<algorithm> ...
- 2018.08.20 loj#115. 无源汇有上下界可行流(模板)
传送门 又get到一个新技能,好兴奋的说啊. 一道无源汇有上下界可行流的模板题. 其实这东西也不难,就是将下界变形而已. 准确来说,就是对于每个点,我们算出会从它那里强制流入与流出的流量,然后与超级源 ...
- LOJ.117.[模板]有源汇有上下界最小流(Dinic)
题目链接 有源汇有上下界最小流 Sol1. 首先和无源汇网络流一样建图,求SS->TT最大流: 然后连边(T->S,[0,INF]),再求一遍SS->TT最大流,答案为新添加边的流量 ...
- loj #116. 有源汇有上下界最大流
题目链接 有源汇有上下界最大流,->上下界网络流 注意细节,重置cur和dis数组时,有n+2个点 #include<cstdio> #include<algorithm> ...
- sgu 176 Flow construction(有源汇的上下界最小流)
[题目链接] http://acm.hust.edu.cn/vjudge/problem/viewProblem.action?id=11025 [模型] 有源汇点的上下界最小流.即既满足上下界又满足 ...
- Flow construction SGU - 176 有源汇有上下界最小流 二分法和回流法
/** 题目:Flow construction SGU - 176 链接:https://vjudge.net/problem/SGU-176 题意: 有源汇有上下界的最小流. 给定n个点,m个管道 ...
- Loj#116-[模板]有源汇有上下界最大流
正题 题目链接:https://loj.ac/p/116 题目大意 \(n\)个点\(m\)条边的一张图,每条边有流量上下限制,求源点到汇点的最大流. 解题思路 先别急着求上面那个,考虑一下怎么求无源 ...
- Crazy Circuits HDU - 3157(有源汇有上下界最小流)
给出每条边的下界 求最小流 板题 提供两个板子代码 虽然这个题 第一个比较快 但在loj上https://loj.ac/problem/117 的板题 第一个1700+ms 第二个才600+ms ...
随机推荐
- cmd查看电脑是32位还是64位
代码如下 @echo off if "%PROCESSOR_ARCHITECTURE%" == "AMD64" ( echo OS is 64bit) EL ...
- 17.在Action获取Scope对象
转自:https://wenku.baidu.com/view/84fa86ae360cba1aa911da02.html 引言:在前面的Action操作中,关键就是Action中的exectue方法 ...
- gulp css 压缩 合并
//导入工具包 require('node_modules里对应模块') var gulp = require('gulp'), //本地安装gulp所用到的地方 concat = require(' ...
- HTML 表格标签
<table border="1"> <tr> <td>row 1, cell 1</td> <td>row 1, ce ...
- Mysql 表名大写 找不到表
原来Linux下的MySQL默认是区分表名大小写的,通过如下设置,可以让MySQL不区分表名大小写:1.用root登录,修改 /etc/my.cnf:2.在[mysqld]节点下,加入一行: lowe ...
- eclipse 创建注释模板
使用 Alt+Shift+J 可以快速注释. 我们每次手动敲入作者,时间,版本等信息,有一些重复,可通过设置eclipse注释模板,减少工作量. Window -> preference -& ...
- Simple2D-25 精灵动作
精灵动画作用在精灵上,使精灵表现出动画效果.本文将详细说明如何创建一个简单的动作系统,暂时只有 4 中基本的动作——平移.旋转.缩放和 Alpha 变化,并且这些动作能够自由组合,组成串行动作或并行动 ...
- Simple2D-18(音乐播放器)使用 bass 音频库
BASS 简介 BASS是一个在多个平台上用于软件的音频库.其目的是为开发人员提供功能强大且高效的示例流(MP3,MP2,MP1,OGG,WAV,AIFF),MOD 音乐(XM,IT,S3M,MOD ...
- UI5-文档-4.26-(Optional) Remote OData Service
到目前为止,我们已经使用了本地JSON数据,但是现在我们将访问一个真正的OData服务来可视化远程数据. 用可公开获得的Northwind OData服务显示并替换发票模型的JSONModel类型,以 ...
- Haskell语言学习笔记(46)Parsec(3)
Applicative Parsing 使用 Applicative 式的 Parser. 包括使用 (<$>), (<*>), (<$), (<*), (*> ...