Satz von Robbins

Der Satz von Robbins (nach Herbert Robbins) ist ein Satz aus der Graphentheorie der einen Zusammenhang zwischen dem Kantenzusammenhang eines ungerichteten Graphen und der Möglichkeit die Kanten so zu orientieren, dass ein stark zusammenhängender gerichteter Graph entsteht herstellt.

Der Satz besagt, dass die Kanten eines zusammenhängender ungerichteten Graphen genau dann so orientiert werden können, dass der entstehende gerichtete Graph stark zusammenhängend ist wenn der ursprüngliche Graph 2-fach kantenzusammenhängend ist (keine Brücken enthält).

Formulierung des Satzes

Graphen

Ein zusammenhängender ungerichteten Graphen hat genau dann eine stark zusammenhängende Orientierung wenn der ursprüngliche Graph 2-fach kantenzusammenhängend ist.

Unter einer Orientierung eines ungerichten Graphen G = ( V , E ) {\displaystyle G=(V,E)} versteht man einen gerichteter Graph O = ( V , E ) {\displaystyle O=(V,E')} sodass für jede ungerichte Kante { v , u } E {\displaystyle \{v,u\}\in E} genau eine der gerichteten Kanten ( v , u ) , ( u , v ) {\displaystyle (v,u),(u,v)} in E {\displaystyle E'} ist.

Multigraphen

Der Satz kann auf Multigraphen verallgemeinert werden[1].

Ein zusammenhängender Multigraph hat genau dann eine stark zusammenhängende Orientierung wenn der ursprüngliche Multigraph 2-fach kantenzusammenhängend ist.

Gemischte Graphen

Boesch und Tindell haben den Satz von Robbins auf gemischte Graphen, Graphen die sowohl gerichtete als auch ungerichtete Kanten enthalten[1].

Ein solcher Graph ist zusammenhängend, wenn es für jedes Paar von Knoten u , v {\displaystyle u,v} einen Pfad von u {\displaystyle u} nach v {\displaystyle v} gibt, wobei gerichtete Kanten nur in der gegebenen Richtung verwendet werden durften.

Ein zusammenhängender gemischter Multigraph hat genau dann eine stark zusammenhängende Orientierung, wenn er 2-fach kantenzusammenhängend ist.

Algorithmus

Der folgende Algorithmus berechnet für einen 2-fach kantenzusammenhängen Graphen G = ( V , E ) {\displaystyle G=(V,E)} eine Orientierung H {\displaystyle H} von G {\displaystyle G} sodass H {\displaystyle H} stark zusammenhängend ist. Er geht auf die Informatiker John E. Hopcroft und Robert Tarjan[2] zurück.

Der Algorithmus geht in zwei Schritten vor: Zuerst werden die Kanten eines Gerüstes orientiert, das über Tiefensuche bestimmt wird, anschließend werden die restlichen Kanten orientiert.

Es sei

  • M {\displaystyle M} die Menge der markierten Knoten,
  • N M {\displaystyle NM} die Menge der nicht markierten Knoten,
  • m : V N {\displaystyle m\colon V\to \mathbb {N} } die Markierung der Knoten,
  • O M {\displaystyle OM} die Menge der Bögen, die durch die Orientierung der Kanten von G {\displaystyle G} entstanden sind.

1. Wähle einen beliebigen Knoten x V {\displaystyle x\in V} von G {\displaystyle G} aus, der markiert wird:

Setze m ( x ) = 1 ; M = { x } ; N M = V { x } ; O M = {\displaystyle m(x)=1;M=\{x\};NM=V\setminus \{x\};OM=\emptyset }

2. Suche jetzt einen Knoten y {\displaystyle y} von M {\displaystyle M} , der eine maximale Markierung m ( y ) {\displaystyle m(y)} und gleichfalls adjazent zu einem Knoten z {\displaystyle z} aus N M {\displaystyle NM} ist. Markiere jetzt z {\displaystyle z} mit m ( z ) = m ( y ) + 1 {\displaystyle m(z)=m(y)+1} . Orientiere anschließend die Kante { y , z } {\displaystyle \{y,z\}} von y {\displaystyle y} zu z {\displaystyle z} , so dass der Bogen ( y , z ) {\displaystyle (y,z)} entsteht.

Der markierte Knoten z {\displaystyle z} wird aus N M {\displaystyle NM} entfernt und zu M {\displaystyle M} hinzugefügt, und der Bogen ( y , z ) {\displaystyle (y,z)} wird zu O M {\displaystyle OM} hinzugefügt:

M = M { z } ; N M = N M { z } ; O M = O M { ( y , z ) } {\displaystyle M=M\cup \{z\};NM=NM\setminus \{z\};OM=OM\cup \{(y,z)\}}

Überprüfe, ob alle Knoten markiert wurden: Gilt M V {\displaystyle M\neq V} , dann wiederhole Schritt 2.

3. Es gilt:

  • Alle Knoten wurden markiert: M = V {\displaystyle M=V} ,
  • ein Gerüst von G {\displaystyle G} ist orientiert.

Es lässt sich beweisen, dass alle Kanten, die jetzt noch keine Richtung haben, immer zwei Knoten mit unterschiedlicher Markierung verbinden. Jede nicht orientierte Kante { x , y } {\displaystyle \{x,y\}} mit m ( x ) > m ( y ) {\displaystyle m(x)>m(y)} wird nun von x {\displaystyle x} nach y {\displaystyle y} orientiert, d. h. vom Knoten mit der größeren zum Knoten mit der kleineren Markierung, und zu O M {\displaystyle OM} hinzugefügt.

Die auf diese Weise konstruierte Orientierung H = ( V , O M ) {\displaystyle H=(V,OM)} des Graphen G {\displaystyle G} ist stark zusammenhängend.

Literatur

  • Frank Bosch, Ralph Tindell: Robbins's theorem for mixed multigraphs. In: American Mathematical Monthly. Band 87, Nr. 9, 1980, S. 716–719, doi:10.2307/2321858. 
  • John Hopcroft, Robert Tarjan: Algorithm 447: efficient algorithms for graph manipulation. In: Communications of the ACM. Band 16, Nr. 6, 1973, S. 372–378, doi:10.1145/362248.362272. 
  • Herbert Robbins: A theorem on graphs, with an application to a problem on traffic control. In: American Mathematical Monthly. Band 46, 1939, S. 281–283, doi:10.2307/2303897. 

Einzelnachweise

  1. a b Boesch und Tindell (1980)
  2. Hopcroft and Tarjan (1973)