-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathdicnic.cpp
109 lines (96 loc) · 2.22 KB
/
dicnic.cpp
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
/* Author: zyy@nju
Date: 2021.1.12
Time Complexity: O(V^2E)
Usage: Modify Init();
适合重边累加的场景 */
#include <bits/stdc++.h>
#define rep(i, a, b) for (int i = a; i < (b); ++i)
using namespace std;
const int INF = 0x3f3f3f3f;
const int MAXE = 5005;
class FlowEdge {
public:
int u, v;
int cap, flow = 0;
FlowEdge(int u, int v, int cap) : u(u), v(v), cap(cap) {}
};
int n = 0, m = 0, tot = 0;
int s = 0, t = 0;
vector<FlowEdge> edges;
vector<int> adj[MAXE]; // SAVE EDGE ID!
int level[MAXE];
int ptr[MAXE];
queue<int> q;
void addEdge(int u, int v, int cap) {
edges.push_back({u, v, cap});
edges.push_back({v, u, 0});
adj[u].push_back(tot++);
adj[v].push_back(tot++);
}
bool bfs() {
while (!q.empty()) {
int u = q.front();
q.pop();
for (int id : adj[u]) {
FlowEdge e = edges[id];
if (e.cap - e.flow < 1)
continue;
if (level[e.v] != -1)
continue;
level[e.v] = level[u] + 1;
q.push(e.v);
}
}
return level[t] != -1;
}
int dfs(int u, int pushed) {
if (!pushed)
return 0;
if (u == t)
return pushed;
for (int &cid = ptr[u]; cid < (int)adj[u].size(); ++cid) {
int id = adj[u][cid];
FlowEdge e = edges[id];
int v = e.v;
if (level[v] != level[u] + 1 || e.cap - e.flow < 1)
continue;
int delta = dfs(v, min(pushed, e.cap - e.flow));
if (!delta)
continue;
edges[id].flow += delta;
edges[id ^ 1].flow -= delta;
return delta;
}
return 0;
}
int maxFlow() {
int ret = 0;
while (true) {
memset(level, -1, sizeof(level));
level[s] = 0;
q.push(s);
if (!bfs())
break;
memset(ptr, 0, sizeof(ptr));
while (true) {
int pushed = dfs(s, INF);
if (!pushed)
break;
ret += pushed;
}
}
return ret;
}
void init() {
scanf("%d%d%d%d", &n, &m, &s, &t);
rep(i, 0, m) {
int u, v, cap;
scanf("%d%d%d", &u, &v, &cap);
addEdge(u, v, cap);
}
}
int main() {
init();
printf("%d\n", maxFlow());
return 0;
}