Remove ads
De Wikipédia, l'encyclopédie libre
En informatique et en théorie des graphes, l'algorithme d'Edmonds–Karp (ou algorithme d'Edmonds et Karp) est une spécialisation de l'algorithme de Ford-Fulkerson de résolution du problème de flot maximum dans un réseau, en temps O(V E2). Il est asymptotiquement plus lent que l'algorithme de poussage/reétiquetage[1] qui utilise une heuristique basée sur une pile et qui est en temps O(V3), mais il est souvent plus rapide en pratique pour des graphes denses. L'algorithme a été publié d'abord par Yefim (Chaim) Dinic en 1970[2] puis et indépendamment par Jack Edmonds et Richard Karp en 1972[3]. L'algorithme de Dinic contient un critère de sélection supplémentaire qui réduit le temps de calcul à O(V2 E).
L'algorithme est identique à l'algorithme de Ford-Fulkerson, à l'exception de l'ordre de recherche utilisé pour déterminer un chemin augmentant. Le chemin trouvé doit être un chemin le plus court (en nombre d'arcs) qui possède une capacité positive, dans le graphe résiduel. Un tel chemin peut être trouvé par un parcours en largeur dans le graphe résiduel, en supposant que les arcs ont tous une longueur unité.
Le temps d'exécution de O(V E2) s'obtient en constatant que chaque chemin augmentant peut être trouvé en temps O(E), qu'à chaque fois au moins un arc de E est saturé, que la distance de la source à un arc saturé par le chemin augmentant croît à chaque fois que l'arc est saturé, et que cette longueur est au plus V. Une autre propriété de cet algorithme est que la longueur du plus court chemin augmentant croît. Une démonstration de l'algorithme est donnée dans le livre Introduction à l'algorithmique de Cormen et al[4].
On part du réseau ci-dessous, à sept nœuds. La source est , le puits est . Les capacités sont indiquées sur les arcs.
Dans les couples d'étiquettes des arcs, est le flot courant, et est la capacité. La capacité résiduelle de vers est par définition
c'est-à-dire la capacité totale, diminuée du flot déjà utilisé. Si le flot de vers est supérieur à la capacité, la capacité résiduelle est négative, et sa contribution est négative.
On peut observer que la longueur du chemin augmentant croît, et que les chemins trouvés sont les plus courts possible (en nombre d'arcs). Le théorème flot-max/coupe-min stipule que le flot trouvé, dont la valeur est 5, est égal à la valeur d'une coupe minimum séparant la source du puits. Dans l'exemple une coupe partitionne les sommets en et , et sa capacité est
Une description de plus haut niveau est donnée dans l'algorithme de Ford-Fulkerson.
algorithm EdmondsKarp input: C[1..n, 1..n] (matrice des capacités) E[1..n, 1..?] (listes des voisins) s (source) t (puits) output: f (valeur du flot maximum) F (matrice donnant un flot valide de valeur maximum) f := 0 (le flot initial est nul) F := array(1..n, 1..n) (la capacité résiduelle de u à v est C[u,v] - F[u,v]) forever m, P := BreadthFirstSearch(C, E, s, t, F) if m = 0 break f := f + m (Backtrack et noter le flot) v := t while v ≠ s u := P[v] F[u,v] := F[u,v] + m F[v,u] := F[v,u] - m v := u return (f, F) algorithm BreadthFirstSearch input: C, E, s, t, F output: M[t] (capacité du chemin trouvé) P (table des parents) P := array(1..n) for u in 1..n P[u] := -1 P[s] := -2 (pour assurer que la source n'est pas redécouverte) M := array(1..n) (capacité du chemin trouvé jusqu'au nœud) M[s] := ∞ Q := queue() Q.push(s) while Q.size() > 0 u := Q.pop() for v in E[u] (s'il y a une capacité disponible, et si v n'a pas été vu durant la recherche) if C[u,v] - F[u,v] > 0 and P[v] = -1 P[v] := u M[v] := min(M[u], C[u,v] - F[u,v]) if v ≠ t Q.push(v) else return M[t], P return 0, P
Seamless Wikipedia browsing. On steroids.
Every time you click a link to Wikipedia, Wiktionary or Wikiquote in your browser's search results, it will show the modern Wikiwand interface.
Wikiwand extension is a five stars, simple, with minimum permission required to keep your browsing private, safe and transparent.