Random Insertion Algorithmus

aus Wikipedia, der freien Enzyklopädie
(Weitergeleitet von RANDIN)

Der Random Insertion Algorithmus (von Englisch random insertion, dt. „zufälliges Einfügen“) gehört zur Klasse der Einfüge-Heuristiken zur Lösung des Problems des Handlungsreisenden.[1]

Algorithmus

Der Algorithmus fügt in jedem Schritt eine mit einem gleichverteilenden Zufallsgenerator gewählte Stadt in die vorhandene Teilroute ein. Danach wird die gewählte Stadt dort eingefügt, wo sie die geringste (kleinste) Verlängerung der bisherigen Teilroute verursacht. Der auch RANDIN bezeichnete Algorithmus besteht also genaugenommen aus den zwei Teilen:[2]

  • Zufällige Auswahl der nächsten Stadt – „RANDom selection“
  • Optimales Einfügen der Stadt in die bestehende Teilroute – „cheapest INsertion“

Das Verfahren wurde ursprünglich von Karg und Thompson vorgeschlagen.[2][3]

Bewertung

Die Laufzeit des Algorithmus ist quadratisch in der Anzahl der Städte.[4] Die Heuristik liefert in der Praxis sehr gute Ergebnisse. Allerdings kann man Eingabeinstanzen mit Städten konstruieren, bei der die gefundene Tour um einen Faktor länger ist als die kürzeste Tour.[5] Als obere Grenze für die Abweichung der gefundenen Tour von der optimalen ist der Faktor bekannt, der für alle Einfüge-Heuristiken gilt.[6]

Alternativen

Alternative Heuristiken benutzen zum Einfügen z. B. jeweils die weitentfernteste Stadt (FARIN; von „farthest insertion“) oder die nächstentfernteste Stadt (NEARIN; von „nearest insertion“).

Fußnoten

  1. Roland Schmitz. Theoretische Informatik für Dummies. Wiley, 2019. Vorschau in Google Books
  2. a b The Solution of Travelling Salesman Problems Based on Industrial Data Buddhadev Roychoudhury, John F. Muth. The Journal of the Operational Research Society, Vol. 46, No. 3 (Mar., 1995), pp. 347–353
  3. Robert L. Karg and Gerald L. Thompson (1964) A heuristic approach to solving traveling salesman problems. Mgmt Sci. 10, 225–248. Kurzzusammenfassung: [1]
  4. https://stemlounge.com/animated-algorithms-for-the-traveling-salesman-problem/