Längster Pfad
Die Aufgabe, den einfachen Weg maximaler Länge in einem gegebenen Graphen zu finden, bezeichnet man in der Graphentheorie und der theoretischen Informatik als Problem des längsten Weges (englisch longest path problem). Ein Weg heißt einfach, wenn er keinen Knoten mehrfach enthält. Die Länge des Weges kann auf zwei Arten gemessen werden: entweder durch die Anzahl der Kanten oder (in einem gewichteten Graphen) durch die Summe der Gewichte seiner Kanten.
Im Gegensatz zum Problem des kürzesten Weges, welches sich in polynomieller Laufzeit lösen lässt, gehört das Problem des längsten Weges zu der Gruppe der NP-schweren Probleme. Dies bedeutet, dass es sich nicht in polynomieller Laufzeit lösen lässt, außer wenn P=NP wäre. Auch eine Approximation ist schwierig ist. Das Problem kann jedoch für gerichtete, nicht-zyklische Graphen mithilfe einer topologischen Sortierung in linearer Zeit gelöst werden.[1] Ein wichtiges Anwendungsgebiet ist das Finden des kritischen Weges in Planungsaufgaben.
NP-Schwere
[Bearbeiten | Quelltext bearbeiten]Die NP-Schwere des ungewichteten längsten Weges kann mit Hilfe des Hamiltonwegproblems gezeigt werden. Ein Graph hat nur dann einen Hamiltonweg, wenn sein längster Weg die Länge hat, wobei die Anzahl der Knoten in ist. Da das Hamiltonwegproblem NP-vollständig ist, ist auch die Entscheidungsversion des längsten Weges NP-vollständig. In der Entscheidungsversion besteht der Input aus dem Graphen und einer Zahl . Der Output ist "ja", sofern einen einfachen Pfad mit oder mehr Kanten enthält.[2]
Wenn das Problem des längsten Weges in polynomieller Laufzeit gelöst werden könnte, so könnte damit die Entscheidungsversion durch einen Vergleich der Länge des längsten Weges mit gelöst werden. Daher ist das Problem des längsten Weges NP-schwer. Die Frage „Gibt es in einem gegebenen Graphen einen Pfad mit mindestens k Kanten“ ist NP-vollständig.[3]
In einem gewichteten vollständigen Graphen ist das Problem des gewichteten längsten Weges äquivalent zum Problem des Handlungsreisenden, da der längste Weg notwendigerweise alle Knoten enthält.[4]
Weblinks
[Bearbeiten | Quelltext bearbeiten]- "Find the Longest Path", song by Dan Barrett
Einzelnachweise
[Bearbeiten | Quelltext bearbeiten]- ↑ Noltemeier, Hartmut: Graphentheoretische Konzepte und Algorithmen. 3. Auflage. Vieweg+Teubner Verlag, Wiesbaden 2012, ISBN 978-3-8348-1849-2, S. 191 f.
- ↑ Alexander Schrijver: Combinatorial Optimization: Polyhedra and Efficiency, Volume 1. Band 24. Springer, 2003, ISBN 3-540-44389-4, S. 114.
- ↑ Thomas H Cormen, Charles E Leiserson, Ronald L Rivest, Clifford Stein (Hrsg.): Introduction To Algorithms. 2. Auflage. MIT Press, 2003, ISBN 0-262-03293-7, S. 978.
- ↑ Eugene Lawler: Combinatorial Optimization: Networks and Matroids. Courier Dover Publications, 2001, ISBN 0-486-41453-1, S. 64.