-
Notifications
You must be signed in to change notification settings - Fork 2.1k
/
Copy pathFord_Fulkerson_Method.c
114 lines (103 loc) · 2.61 KB
/
Ford_Fulkerson_Method.c
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
110
111
112
113
#include <stdio.h>
#define WHITE 0
#define GRAY 1
#define BLACK 2
#define MAX_NODES 1000
#define oo 1000000000
int n; // number of nodes
int e; // number of edges
int capacity[MAX_NODES][MAX_NODES]; // capacity matrix
int flow[MAX_NODES][MAX_NODES]; // flow matrix
int color[MAX_NODES]; // needed for breadth-first search
int pred[MAX_NODES]; // array to store augmenting path
int min (int x, int y) {
return x < y ? x : y; // returns minimum of x and y
}
int head, tail;
int q[MAX_NODES + 2];
void enqueue (int x) {
q[tail] = x;
tail++;
color[x] = GRAY;
}
int dequeue () {
int x = q[head];
head++;
color[x] = BLACK;
return x;
}
int bfs (int start, int target) {
int u,v;
for (u = 0; u < n; u++) {
color[u] = WHITE;
}
head = tail = 0;
enqueue(start);
pred[start] = -1;
while (head != tail) {
u = dequeue();
// Search all adjacent white nodes v. If the capacity
// from u to v in the residual network is positive,
// enqueue v.
for (v = 0; v < n; v++) {
if (color[v] == WHITE && capacity[u][v] - flow[u][v] > 0) {
enqueue(v);
pred[v] = u;
}
}
}
// If the color of the target node is black now,
// it means that we reached it.
return color[target] == BLACK;
}
int max_flow (int source, int sink) {
int i, j, u;
// Initialize empty flow.
int max_flow = 0;
for (i = 0; i < n; i++) {
for (j = 0; j < n; j++) {
flow[i][j] = 0;
}
}
// While there exists an augmenting path,
// increment the flow along this path.
while (bfs(source, sink)) {
// Determine the amount by which we can increment the flow.
int increment = oo;
for (u = n - 1; pred[u] >= 0; u = pred[u]) {
increment = min(increment, capacity[pred[u]][u] - flow[pred[u]][u]);
}
// Now increment the flow.
for (u = n - 1; pred[u] >= 0; u = pred[u]) {
flow[pred[u]][u] += increment;
flow[u][pred[u]] -= increment;
}
max_flow += increment;
}
// No augmenting path anymore. We are done.
return max_flow;
}
//Reading the input file and the main program
void read_input_file() {
int a, b, c, i, j;
FILE* input = fopen("mf.in", "r");
// read number of nodes and edges
fscanf(input, "%d %d", &n, &e);
// initialize empty capacity matrix
for (i = 0; i < n; i++) {
for (j = 0; j < n; j++) {
capacity[i][j] = 0;
}
}
// read edge capacities
for (i=0; i<e; i++) {
fscanf(input, "%d %d %d", &a, &b, &c);
capacity[a][b] = c;
}
fclose(input);
}
int main () {
read_input_file();
printf("%d\n", max_flow(0, n - 1));
return 0;
}