Algorithme de Chu-Liu/Edmonds

De testwiki
Aller à la navigation Aller à la recherche

Modèle:Voir homonymes

En théorie des graphes, l'algorithme d'Edmonds ou algorithme de Chu-Liu/Edmonds est un algorithme fournissant une arborescence couvrante de poids minimal dans un graphe. Il s'agit de la version orientée d'un arbre couvrant de poids minimal. L'algorithme a été proposé indépendamment par Yoeng-Jin Chu et Tseng-Hong Liu (1965), puis par Jack Edmonds (1967).

Algorithme

Description

L'algorithme prend en entrée un graphe orienté G=V,EV est l'ensemble des sommets et E est l'ensemble des arcs. Soit un sommet r appelé la racine, et une valeur réelle de poids w(e) pour chaque arc eE. L'algorithme renvoie une arborescence couvrante de poids minimal A ancrée à la racine r, le poids d'une arborescence étant défini comme la somme des poids des arcs, w(A)=eAw(e).

L'algorithme peut être exécuté de manière récursive. Soit f(G,r,w) la fonction qui retourne une arborescence couvrante de poids minimal ancrée à la racine . On commence par supprimer tous les arcs de E dont la destination est r. On remplace également tous les ensembles d'arcs parallèles (les arcs ayant la même origine et la même destination) par un seul arc avec un poids égal au poids minimal de l'ensemble associé.

Maintenant, pour chaque sommet v autre que la racine, on prend l'arc de poids le plus faible dont la destination est v. On appelle l'origine de cet arc π(v). Si l'ensemble d'arcs P={(π(v),v)vVr} ne contient pas de cycles, alors f(G,r,w)=P.

Sinon, P contient au moins un cycle. On choisit arbitrairement l'un de ces cycles. Soit C ce cycle. Nous allons maintenant définir un nouveau graphe orienté et pondéré G=S,E dans lequel le cycle C est "contracté" dans un seul sommet comme suit :

Les sommets de V sont les sommets de VC plus un nouveau sommet dénoté vC.

  • Si (u,v) est un arc de E avec uC et vC (un arc entrant dans le cycle), alors on inclut dans E un nouvel arc e=(u,vC), et on définit w(e)=w(u,v)w(π(v),v).
  • Si (u,v) est un arc de E avec uC et vC (un arc sortant du cycle), alors on inclut dans E un nouvel arc e=(vC,v), et on définit w(e)=w(u,v).
  • Si (u,v) est un arc de E avec uC et vC (un arc non-relié au cycle), alors on inclut dans E un nouvel arc e=(u,v), et on définit w(e)=w(u,v).

Pour chaque arc de E, on garde en mémoire l'arc de E auquel il correspond.

Maintenant, on récupère une arborescence couvrante de poids minimal A pour G en appelant f(G,r,w). Comme A est une arborescence couvrante, chacun de ses sommets a exactement un arc entrant. Soit (u,vC) l'unique arc de A entrant dans vC. Cet arc correspond à un arc (u,v)E avec vC. On supprime (π(v),v)de C, pour briser le cycle. On garde tous les autres arcs de C. Pour chaque arc dans A, on garde son arc correspondant dans E. Maintenant, f(G,r,w) est défini par les arcs que nous avons gardés, qui forment une arborescence couvrante de poids minimal.On note que f(G,r,w) est défini à l'aide de f(G,r,w), avec G ayant strictement moins de sommets que G. Trouver f(G,r,w) pour un graphe contenant un seul sommet est trivial (il s'agit de G lui-même), ainsi la terminaison de l'algorithme est garantie.

Complexité de l'algorithme

La complexité en temps de cet algorithme est O(EV). Une implémentation plus rapide de l'algorithme a été élaborée par Robert Tarjan et a une complexité en temps O(ElogV) pour un graphe creux et O(V2) pour un graphe dense. C'est aussi rapide que l'algorithme de Prim pour un arbre couvrant de poids minimal non-orienté. En 1986, Gabow, Galil, Spencer, Compton, et Tarjan ont élaboré une implémentation plus rapide, avec une complexité en temps O(E+VlogV).

Références

Liens externes

Modèle:Portail