Кратчайший путь в ациклическом графе
Формулировка задачи
Пусть дан ациклический взвешенный граф. Требуется найти вес кратчайшего пути из u в v
Определение: |
Кратчайший путь из u в v – это такой путь из u в v, что его вес меньше или равен веса любого другого пути из u в v |
Решение
Пусть d — матрица, где d[i] — вес кратчайшего пути из u в i. Изначально значения d равны бесконечности, кроме d[u], который равен 0. Пусть w[i][j] - вес ребра из i в j. Будем обходить граф в порядке топологической сортировки. Получаем следующие соотношения:
Так как мы обходим граф в порядке топологической сортировки, то на i-ом шаге во всех d[j] (j такие, что: /exist ребро из j в i) уже записаны оптимальные ответы, и следовательно в d[i] так же будет записан оптимальный ответ.
Реализация
Реализуем данный алгоритм методом "динамика вперед":
//d, w - матрицы как в описании, p - матрица индексов вершин графа в порядке топологической сортировки, i, j - счетчики
inputData() //считывание данных
for i = 1 to n d[i] = infinity
topSort() //топологическая сортировка
d[p[u]] = 0
for i = 1 to n for j: /exist p[i] \rightsquigarrow j d[j] = min(d[j], d[p[i]] + w[p[i]][j])
writeData(); // запись данных
Пример
Пусть дан граф со следующими весами w ребер:
1 | 2 | 3 | 4 | |
1 | 0 | 1 | 1 | 4 |
2 | - | 0 | - | 2 |
3 | - | - | 0 | 1 |
4 | - | - | - | 0 |
Требуется найти путь из 1 в 4. матрица d будет выглядеть следующим образом:
1 | 2 | 3 | 4 |
0 | 1 | 1 | 2 |
Ответ будет равен 2.