Алгоритм Форда-Беллмана — различия между версиями
м |
|||
Строка 1: | Строка 1: | ||
+ | {{В разработке}} | ||
+ | |||
==Алгоритм== | ==Алгоритм== | ||
:Для заданного взвешенного графа <tex>G = (V, E)</tex> алгоритм находит кратчайшие пути из заданной вершины <tex> s </tex> до всех остальных вершин.<br> | :Для заданного взвешенного графа <tex>G = (V, E)</tex> алгоритм находит кратчайшие пути из заданной вершины <tex> s </tex> до всех остальных вершин.<br> | ||
Строка 23: | Строка 25: | ||
:Также релаксацию можно свести к одномерному случаю (одномерный массив будем обозначать <tex>d'</tex>): | :Также релаксацию можно свести к одномерному случаю (одномерный массив будем обозначать <tex>d'</tex>): | ||
− | :<tex>d'[u] \gets \min(d'[u], \; d'[v] + \omega(u | + | :<tex>d'[u] \gets \min(d'[u], \; d'[v] + \omega(v,u))</tex> |
==Корректность== | ==Корректность== | ||
Строка 34: | Строка 36: | ||
: '''Индукционный переход.''' | : '''Индукционный переход.''' | ||
::Сначала докажем, что <tex> \rho(s, u) \leqslant d'[u]</tex>. | ::Сначала докажем, что <tex> \rho(s, u) \leqslant d'[u]</tex>. | ||
− | ::Предположим, что <tex>d'[u] + \omega( | + | ::Предположим, что <tex>d'[u] \geqslant \rho(s,u)</tex>, тогда <tex> d'[u] + \omega(uv) \geqslant \rho(s,u) + \omega(u,v)</tex> то есть вес любого найденного пути не меньше, чем <tex>\rho(s, v)</tex>, что неверно, следовательно неравенство выполняется. |
Строка 59: | Строка 61: | ||
'''Bellman_Ford(G, s)''' | '''Bellman_Ford(G, s)''' | ||
− | '''for''' для каждой <tex>v \in V | + | '''for''' для каждой <tex>v \in V</tex> |
<tex> d[v] \leftarrow \mathcal {1} </tex> | <tex> d[v] \leftarrow \mathcal {1} </tex> | ||
<tex>d[s] \leftarrow 0 </tex> | <tex>d[s] \leftarrow 0 </tex> | ||
− | '''for''' <tex> i \leftarrow 1 </tex> '''to''' <tex> \mid V | + | '''for''' <tex> i \leftarrow 1 </tex> '''to''' <tex> \mid V \mid - 1 </tex> |
− | '''for''' для каждого ребра <tex> (u, v) \in E | + | '''for''' для каждого ребра <tex> (u, v) \in E </tex> |
'''if''' <tex>d[v] > d[u] + \omega(u, v) </tex> | '''if''' <tex>d[v] > d[u] + \omega(u, v) </tex> | ||
'''then''' <tex>d[v] \leftarrow d[u] + \omega(u, v)</tex> | '''then''' <tex>d[v] \leftarrow d[u] + \omega(u, v)</tex> | ||
− | '''for''' для каждого ребра <tex> (u, v) \in E | + | '''for''' для каждого ребра <tex> (u, v) \in E </tex> |
'''if''' <tex>d[v] > d[u] + \omega(u, v) </tex> | '''if''' <tex>d[v] > d[u] + \omega(u, v) </tex> | ||
'''then''' '''return''' <tex> \mathit false</tex> | '''then''' '''return''' <tex> \mathit false</tex> | ||
Строка 78: | Строка 80: | ||
{{Лемма | {{Лемма | ||
− | |statement=Пусть <tex>G = (V, E) </tex> — взвешенный ориентированный граф, <tex> s </tex> — стартовая вершина.<br>Тогда после завершения <tex> \mid V | + | |statement=Пусть <tex>G = (V, E) </tex> — взвешенный ориентированный граф, <tex> s </tex> — стартовая вершина.<br>Тогда после завершения <tex> \mid V \mid - 1 </tex> итераций цикла для всех вершин, достижимых из <tex>s</tex>, выполняется равенство <tex> d[v] = \delta (s, v) </tex>. |
|proof=:Рассмотрим произвольную вершину <tex>v</tex>, достижимую из <tex>s</tex>. | |proof=:Рассмотрим произвольную вершину <tex>v</tex>, достижимую из <tex>s</tex>. | ||
:Пусть <tex>p = \langle v_0,..., v_{k} \rangle </tex>, где <tex>v_0 = s</tex>, <tex>v_{k} = v</tex> — кратчайший ациклический путь из <tex> s </tex> в <tex> v </tex>.<br> | :Пусть <tex>p = \langle v_0,..., v_{k} \rangle </tex>, где <tex>v_0 = s</tex>, <tex>v_{k} = v</tex> — кратчайший ациклический путь из <tex> s </tex> в <tex> v </tex>.<br> | ||
− | :Путь <tex> p </tex> содержит не более <tex> \mid V | + | :Путь <tex> p </tex> содержит не более <tex> \mid V \mid - 1 </tex> ребер. Поэтому <tex>k \le \mid V \mid - 1</tex>. |
Строка 101: | Строка 103: | ||
{{Теорема | {{Теорема | ||
− | |statement=Пусть <tex>G = (V, E) </tex> - взвешенный ориентированный граф, <tex> s </tex> — стартовая вершина.<br>Если граф <tex> G </tex> не содержит отрицательных циклов, достижимых из вершины <tex> s </tex>, то алгоритм возвращает <tex> true </tex> и для всех <tex> v \in V | + | |statement=Пусть <tex>G = (V, E) </tex> - взвешенный ориентированный граф, <tex> s </tex> — стартовая вершина.<br>Если граф <tex> G </tex> не содержит отрицательных циклов, достижимых из вершины <tex> s </tex>, то алгоритм возвращает <tex> true </tex> и для всех <tex> v \in V \ d[v] = \delta (s, v)</tex>.<br>Если граф <tex> G </tex> содержит отрицательные циклы, достижимые из вершины <tex> s </tex>, то алгоритм возвращает <tex> false </tex> |
|proof=:Пусть граф <tex> G </tex> не содержит отрицательных циклов, достижимых из вершины <tex> s </tex>.<br> | |proof=:Пусть граф <tex> G </tex> не содержит отрицательных циклов, достижимых из вершины <tex> s </tex>.<br> | ||
:Тогда если вершина <tex> v </tex> достижима из <tex> s </tex>, то по лемме <tex> d[v] = \delta (s, v)</tex>.<br> | :Тогда если вершина <tex> v </tex> достижима из <tex> s </tex>, то по лемме <tex> d[v] = \delta (s, v)</tex>.<br> | ||
Строка 108: | Строка 110: | ||
:Теперь докажем, что алгоритм вернет значение <tex> true </tex>.<br> | :Теперь докажем, что алгоритм вернет значение <tex> true </tex>.<br> | ||
− | :После выполнения алгоритма верно, что для всех <tex> (u, v) \in E | + | :После выполнения алгоритма верно, что для всех <tex> (u, v) \in E, \ d[v] = \delta (s, v) \leqslant \delta (s, u) + \omega (u,v) = d[u] + \omega (u,v)</tex>, значит ни одна из проверок не вернет значения <tex> false </tex>. |
Строка 122: | Строка 124: | ||
==Сложность== | ==Сложность== | ||
− | :Инициализация занимает <tex> \Theta (V) </tex> времени, каждый из <tex> \mid V | + | :Инициализация занимает <tex> \Theta (V) </tex> времени, каждый из <tex> \mid V \mid - 1 </tex> проходов требует <tex> \Theta (E) </tex> времени, обход по всем ребрам для проверки наличия отрицательного цикла занимает <tex>O(E)</tex> времени.<br>Итого алгоритм Беллмана-Форда работает за <tex>O(V E)</tex> времени. |
== Источники == | == Источники == |
Версия 02:52, 28 февраля 2012
Эта статья находится в разработке!
Содержание
Алгоритм
- Для заданного взвешенного графа
- В случае когда в графе содержатся отрицательные циклы достижимые из алгоритм сообщает, что кратчайших путей не существует.
Введение
- Сначала стоит вспомнить формулу для количества путей длины
- Теперь перепишем ее для пути кратчайшей длины.
- , при этом , а
— стартовая вершина.
Лемма: |
Если существует кратчайший путь от до ,то |
Псевдокод
- Используя приведенные формулы, алгоритм можно реализовать методом динамического программирования.
forfor for
- Также релаксацию можно свести к одномерному случаю (одномерный массив будем обозначать ):
Корректность
Лемма: |
Пусть — взвешенный ориентированный граф, — стартовая вершина.Тогда после завершения итераций цикла выполняется неравенство . |
Доказательство: |
|
Реализация алгоритма и ее корректность
Bellman_Ford(G, s) for для каждойfor to for для каждого ребра if then for для каждого ребра if then return return
- В этом алгоритме используется релаксация, в результате которой
- - фактический вес кратчайшего пути из в вершину .
Лемма: |
Пусть — взвешенный ориентированный граф, — стартовая вершина.Тогда после завершения итераций цикла для всех вершин, достижимых из , выполняется равенство . |
Доказательство: |
|
Теорема: |
Пусть - взвешенный ориентированный граф, — стартовая вершина.Если граф не содержит отрицательных циклов, достижимых из вершины , то алгоритм возвращает и для всех . Если граф содержит отрицательные циклы, достижимые из вершины , то алгоритм возвращает |
Доказательство: |
|
Сложность
- Инициализация занимает
Итого алгоритм Беллмана-Форда работает за времени. времени, каждый из проходов требует времени, обход по всем ребрам для проверки наличия отрицательного цикла занимает времени.
Источники
- Кормен, Т., Лейзерсон, Ч., Ривест, Р., Штайн, К. Алгоритмы: построение и анализ / пер. с англ. — изд. 2-е — М.: Издательский дом «Вильямс», 2009. — с.672 — 676. — ISBN 978-5-8459-0857-5.
- Алгоритм Форда-Беллмана