En kısa yol ağacı - Shortest-path tree - Wikipedia

Verilen bir bağlı, yönsüz grafik G, bir en kısa yol ağacı tepe noktasında köklü v bir yayılan ağaç T nın-nin G, yolun kökten uzaklığı v başka herhangi bir tepe noktasına sen içinde T ... en kısa yol uzaklık v -e sen içinde G.

En kısa yolların iyi tanımlandığı bağlantılı grafiklerde (yani, negatif uzunluklu döngülerin olmadığı yerlerde), aşağıdaki algoritmayı kullanarak en kısa yol ağacı oluşturabiliriz:

  1. Dist hesapla (sen), kökten en kısa yol mesafesi v tepe noktasına sen içinde G kullanma Dijkstra algoritması veya Bellman-Ford algoritması.
  2. Tüm kök olmayan köşeler için senatayabiliriz sen bir ana tepe psen öyle ki psen bağlı senve bu dist (psen) + edge_dist (psen,sen) = dist (sen). İçin birden fazla seçenek olması durumunda psen var, seç psen için en kısa yol var v -e psen mümkün olduğunca az kenarlı; sıfır uzunluklu döngüler olduğunda döngüleri önlemek için bu bağ kırma kuralı gereklidir.
  3. Her bir düğüm ile üst öğesi arasındaki kenarları kullanarak en kısa yol ağacını oluşturun.

Yukarıdaki algoritma, en kısa yol ağaçlarının varlığını garanti eder. Sevmek minimum uzanan ağaçlar, en kısa yol ağaçları genel olarak benzersiz değildir.

Tüm kenar ağırlıklarının bire eşit olduğu grafiklerde, en kısa yol ağaçları, enine arama ağaçlar.

Negatif döngülere sahip grafiklerde, en kısa basit yollar kümesi v diğer tüm köşelerin bir ağaç oluşturması gerekmez.

Ayrıca bakınız

Referanslar

Cahn, Robert S. (1998). Geniş Alan Ağı Tasarımı: Optimizasyon için Kavramlar ve Araçlar. Ağ oluşturma. Morgan Kaufmann. ISBN  978-1558604582.