Алгоритм Форда-Беллмана — различия между версиями
Строка 18: | Строка 18: | ||
'''return''' <tex> \mathit true </tex> | '''return''' <tex> \mathit true </tex> | ||
+ | ==Корректность алгоритма Беллмана-Форда== | ||
+ | {{Лемма | ||
+ | |statement=Пусть <tex>G = (V, E) </tex> -взвешенный ориентированный граф, <tex> s </tex> — стартовая вершина. Тогда после завершения <tex> \mid V[G] \mid - 1 </tex> итераций цикла для всех вершин, достижимых из s выполняется равенство <tex> d[v] = \delta (s, v) </tex>. | ||
+ | |proof=Рассмотрим произвольную вершину <tex> v </tex> достижимую из <tex> s </tex>, <tex> p = {v_0,..., v_{k}} </tex>, где <tex> v_0 = s </tex>, <tex> v_{k} = v </tex> — кратчайший ациклический путь из <tex> s </tex> в <tex> v </tex>. Путь <tex> p </tex> содержит не более <tex> \mid V[G] \mid - 1 </tex> ребер. На каждой из <tex> \mid V[G] \mid - 1 </tex> итераций цикла релаксируются <tex> \mid E[G] \mid </tex> ребер. Среди ребер, прорелаксированных во время i-й итерации находится ребро <tex> (v_{i-1}, v_{i}) </tex>. Поэтому выполнены равенства <tex>d[v] = d[v_{k}] = \delta (s, v_{k}) = \delta (s, v))</tex> | ||
+ | }} | ||
==Сложность== | ==Сложность== | ||
− | Инициализация занимает <tex> \Theta (V) </tex> времени, каждый из <tex> | + | Инициализация занимает <tex> \Theta (V) </tex> времени, каждый из <tex> \mid V[G] \mid - 1 </tex> проходов требует <tex> \Theta (E) </tex> времени, обход по всем ребрам для проверки наличия отрицательного цикла занимает <tex>O(E)</tex> времени. Итого алгоритм Беллмана-Форда работает за <tex>O(V E)</tex> времени. |
Версия 06:35, 1 декабря 2010
Эта статья находится в разработке!
Алгоритм
Для заданного взвешенного графа
алгоритм находит кратчайшие пути из заданной вершины до всех остальных вершин, в случае когда в графе содержатся отрицательные циклы достижимые из алгоритм сообщает, что кратчайших путей не существует.Псевдокод
Bellman_Ford(G, s) for для каждойdo for to do for для каждого ребра do if then for для каждого ребра do if then return return
Корректность алгоритма Беллмана-Форда
Лемма: |
Пусть -взвешенный ориентированный граф, — стартовая вершина. Тогда после завершения итераций цикла для всех вершин, достижимых из s выполняется равенство . |
Доказательство: |
Рассмотрим произвольную вершину | достижимую из , , где , — кратчайший ациклический путь из в . Путь содержит не более ребер. На каждой из итераций цикла релаксируются ребер. Среди ребер, прорелаксированных во время i-й итерации находится ребро . Поэтому выполнены равенства
Сложность
Инициализация занимает
времени, каждый из проходов требует времени, обход по всем ребрам для проверки наличия отрицательного цикла занимает времени. Итого алгоритм Беллмана-Форда работает за времени.