A New Approach to the Maximum-Flow Problem

Andrew V. Goldberg, Robert E. Tarjan

Research output: Contribution to journalArticle

1196 Scopus citations

Abstract

All previously known efficient maximum-flow algorithms work by finding augmenting paths, either one path at a time (as in the original Ford and Fulkerson algorithm) or all shortest-length augmenting paths at once (using the layered network approach of Dinic). An alternative method based on the preflow concept of Karzanov is introduced. A preflow is like a flow, except that the total amount flowing into a vertex is allowed to exceed the total amount flowing out. The method maintains a preflow in the original network and pushes local flow excess toward the sink along what are estimated to be shortest paths. The algorithm and its analysis are simple and intuitive, yet the algorithm runs as fast as any other known method on dense graphs, achieving an O(n3) time bound on an n-vertex graph. By incorporating the dynamic tree data structure of Sleator and Tarjan, we obtain a version of the algorithm running in O(nm log(n2/m)) time on an n-vertex, m-edge graph. This is as fast as any known method for any graph density and faster on graphs of moderate density. The algorithm also admits efficient distributed and parallel implementations. A parallel implementation running in O(n2log n) time using n processors and O(m) space is obtained. This time bound matches that of the Shiloach-Vishkin algorithm, which also uses n processors but requires O(n2) space.

Original languageEnglish (US)
Pages (from-to)921-940
Number of pages20
JournalJournal of the ACM (JACM)
Volume35
Issue number4
DOIs
StatePublished - Oct 1 1988

All Science Journal Classification (ASJC) codes

  • Software
  • Control and Systems Engineering
  • Information Systems
  • Hardware and Architecture
  • Artificial Intelligence

Keywords

  • Dynamic trees
  • maximum-flow problem

Fingerprint Dive into the research topics of 'A New Approach to the Maximum-Flow Problem'. Together they form a unique fingerprint.

  • Cite this