data:image/s3,"s3://crabby-images/ca364/ca36463f9b82c90b6f3e27c6326cdcdc31617e4c" alt=""
Dinic's algorithm
Encyclopedia
Dinic's algorithm is a strongly polynomial algorithm for computing the maximum flow in a flow network
, conceived in 1970 by Israeli (formerly Soviet) computer scientist Yefim Dinitz. The algorithm runs in
time and is similar to the Edmonds–Karp algorithm, which runs in
time, in that it uses shortest augmenting paths. The introduction of the concepts of the level graph and blocking flow enable Dinic's algorithm to achieve its performance.
be a network with
and
the capacity and the flow of the edge
respectively.
blocking flows in the algorithm, where
is the number of vertices in the network. The level graph
can be constructed by Breadth-first search
in
time and a blocking flow in each level graph can be found in
time. Hence, the running time of Dinic's algorithm is
.
Using a data structure called dynamic trees, the running time of finding a blocking flow in each phase can be reduced to
and therefore the running time of Dinic's algorithm can be improved to
.
time, and it can be shown that the number of phases does not exceed
and
. Thus the algorithm runs in
time.
In networks arising during the solution of bipartite matching problem, the number of phases is bounded by
, therefore leading to the
time bound. The resulting algorithm is also known as Hopcroft–Karp algorithm. More generally, this bound holds for any unit network — a network in which each vertex, except for source and sink, either has a single entering edge of capacity one, or a single outgoing edge or capacity one, and all other capacities are arbitrary integers.
, the vertices with labels in red are the values
. The paths in blue form a blocking flow.
(Israel), earlier than the Edmonds–Karp algorithm, which was published in 1972 but was discovered earlier. They independently showed that in the Ford–Fulkerson algorithm, if each augmenting path is the shortest one, the length of the augmenting paths is non-decreasing.
Flow network
In graph theory, a flow network is a directed graph where each edge has a capacity and each edge receives a flow. The amount of flow on an edge cannot exceed the capacity of the edge. Often in Operations Research, a directed graph is called a network, the vertices are called nodes and the edges are...
, conceived in 1970 by Israeli (formerly Soviet) computer scientist Yefim Dinitz. The algorithm runs in
data:image/s3,"s3://crabby-images/822e2/822e25fa93fbb497f5f5bfa7c27e500efd2c9258" alt=""
data:image/s3,"s3://crabby-images/b89ca/b89cab117ee9617806d69741e38c1394998f689d" alt=""
Definition
Letdata:image/s3,"s3://crabby-images/fc65b/fc65ba4cc03c08b669590c3d8b6162e53d6b7815" alt=""
data:image/s3,"s3://crabby-images/e1bca/e1bcad41f485837f467739492cc91ed11b5ec5ae" alt=""
data:image/s3,"s3://crabby-images/43af7/43af7252e59ad34bbc7726f4cc7577d119e44619" alt=""
data:image/s3,"s3://crabby-images/79605/796052682175ede9a55249d14fa8d8c6d70a14cc" alt=""
- The residual capacity is a mapping
defined as,
- if
,
-
-
otherwise.
- if
- The residual graph is the graph
, where
-
.
-
- An augmenting path is an
path in the residual graph
.
- Define
to be the length of the shortest path from
to
in
. Then the level graph of
is the graph
, where
-
.
-
- A blocking flow is an
flow
such that the graph
with
contains no
path.
Algorithm
Dinic's Algorithm- Input: A network
.
- Output: An
flow
of maximum value.
- Set
for each
.
- Construct
from
of
. If
, stop and output
.
- Find a blocking flow
in
.
- Augment flow
by
and go back to step 2.
- Set
Analysis
It can be shown that the number of edges in each blocking flow increases by at least 1 each time and thus there are at mostdata:image/s3,"s3://crabby-images/d7aaa/d7aaa57beed5b93a768526c1353bbb23cbadef2a" alt=""
data:image/s3,"s3://crabby-images/ba863/ba863a5f15221b717c4fd18fceb8d443af9bd66d" alt=""
data:image/s3,"s3://crabby-images/e0fb0/e0fb035162bd2aed76578d85142f681018b3724c" alt=""
Breadth-first search
In graph theory, breadth-first search is a graph search algorithm that begins at the root node and explores all the neighboring nodes...
in
data:image/s3,"s3://crabby-images/80fbc/80fbc2816a824fc153c02dda92fad0e4b2cefa1a" alt=""
data:image/s3,"s3://crabby-images/32538/32538f7db4d56e2fc58bf15494f4641e02ab0407" alt=""
data:image/s3,"s3://crabby-images/e519f/e519f33064e03c036aef897f82b5828bfff1749a" alt=""
Using a data structure called dynamic trees, the running time of finding a blocking flow in each phase can be reduced to
data:image/s3,"s3://crabby-images/0d896/0d896713a77c143e06434e07ec3061f40f511329" alt=""
data:image/s3,"s3://crabby-images/6b990/6b990a64378af26d209b936968326e97412b02be" alt=""
Special cases
In networks with unit capacities, a much stronger time bound holds. Each blocking flow can be found indata:image/s3,"s3://crabby-images/e11bd/e11bdf8eee8522f0ab23db9a5652d6a0551b39de" alt=""
data:image/s3,"s3://crabby-images/02bf5/02bf5b3855ca472934934e0b18237caa7145a570" alt=""
data:image/s3,"s3://crabby-images/4cfff/4cfffa654c097a56b600e298360d7f9e30cc3d99" alt=""
data:image/s3,"s3://crabby-images/563da/563dacb8f36782942dbd3b0d6e1a481978ac66e0" alt=""
In networks arising during the solution of bipartite matching problem, the number of phases is bounded by
data:image/s3,"s3://crabby-images/947d8/947d8518844e666dcf705b2942fa2d84e5701b1a" alt=""
data:image/s3,"s3://crabby-images/fb447/fb44781b83372e631b23a46a7f2708c0247270b9" alt=""
Example
The following is a simulation of the Dinic's algorithm. In the level graphdata:image/s3,"s3://crabby-images/e2e58/e2e58877b2063acd17454ec966c96783c490e433" alt=""
data:image/s3,"s3://crabby-images/9c375/9c375b5c9f113bfb031ed3832fdb130afa23adbf" alt=""
![]() |
![]() |
![]() |
|
---|---|---|---|
1. | |||
The blocking flow consists of
Therefore the blocking flow is of 14 units and the value of flow ![]() |
|||
2. | |||
The blocking flow consists of
Therefore the blocking flow is of 5 units and the value of flow ![]() |
|||
3. | |||
Since ![]() ![]() |
|||
History
Dinic's algorithm was published in 1970 by former Russian Computer Scientist Yefim (Chaim) A. Dinitz , who is today a member of the Computer Science department at Ben-Gurion University of the NegevBen-Gurion University of the Negev
Ben-Gurion University of the Negev is a university in Beersheba, Israel, established in 1969. Ben-Gurion University of the Negev has a current enrollment of 17,400 students, and is one of Israel's fastest growing universities....
(Israel), earlier than the Edmonds–Karp algorithm, which was published in 1972 but was discovered earlier. They independently showed that in the Ford–Fulkerson algorithm, if each augmenting path is the shortest one, the length of the augmenting paths is non-decreasing.