bellmanford @ 2019-08-11 12:22:16
#include<algorithm>
#include<iostream>
#include<cstdlib>
#include<cstring>
#include<cstdio>
#include<cmath>
#include<queue>
using namespace std;
#define OPTIMIZE ios::sync_with_stdio(false); cin.tie(NULL); cout.tie(NULL);
#define In inline
#define Re register
#define db double
#define ll long long
const int M=1e5+5;
int n,m,s,t,tot=0,ans=0,liu[M],pre[M],first[M];
bool vis[M];
struct Edge{
int nxt,to,val;
}e[M<<1];
int read(){
int x=0,y=1;
char ch=getchar();
while(ch<'0'||ch>'9'){
if(ch=='-') y=-1;
ch=getchar();
}
while(ch>='0'&&ch<='9'){
x=x*10+ch-'0';
ch=getchar();
}
return x*y;
}
void add(int x,int y,int z){
tot++;
e[tot].nxt=first[x];
first[x]=tot;
e[tot].to=y;
e[tot].val=z;
}
bool bfs(){
queue<int> Q;
memset(vis,0,sizeof(vis));
Q.push(s);
vis[s]=1;
liu[s]=1<<30;
while(!Q.empty()){
int u=Q.front();
Q.pop();
for(int i=first[u];i;i=e[i].nxt){
int v=e[i].to,w=e[i].val;
if(!vis[v]&&w){
vis[v]=1;
pre[v]=i;
liu[v]=min(liu[u],w);
Q.push(v);
if(v==t) return 1;
}
}
}
return 0;
}
void EK(){
while(bfs()){
int u=t;
while(u!=s){
e[pre[u]].val-=liu[t];
e[pre[u]^1].val+=liu[t];
u=e[pre[u]^1].to;
}
ans+=liu[t];
}
}
int main(){
n=read(),m=read(),s=read(),t=read();
for(int i=1;i<=m;i++){
int x=read(),y=read(),z=read();
add(x,y,z);
add(y,x,0);
}
EK();
printf("%d\n",ans);
}
by Rainy7 @ 2019-08-11 12:47:20
@bellmanford
红名去你的刚学OI
这题EK能过吗??不是用Dinic????(反正我用dinic)
by bellmanford @ 2019-08-11 12:48:23
@路人七 EK不是可以处理10^3-10^4规模的网络吗
by bellmanford @ 2019-08-11 12:48:51
虽然是O(nm^2)
by Rainy7 @ 2019-08-11 12:49:37
@bellmanford 网络流复杂度太玄学了所以我没背..然后我觉得学了EK后面也可能只用dinic就没学..QAQ...
by 寒鸽儿 @ 2019-08-11 13:00:47
刚学OI
by d3NtMDAw @ 2019-08-11 13:26:46
刚学OI就学EK的dalao
by bellmanford @ 2019-08-11 13:49:04
好吧
tot=1
by bellmanford @ 2019-08-11 13:49:23
此贴终结