Алгоритм Форда-Беллмана — различия между версиями
(Переделывание под изложение как на лекции) |
|||
Строка 1: | Строка 1: | ||
+ | {{В разработке}} | ||
+ | |||
==Алгоритм== | ==Алгоритм== | ||
:Для заданного взвешенного графа <tex>G = (V, E)</tex> алгоритм находит кратчайшие пути из заданной вершины <tex> s </tex> до всех остальных вершин.<br> | :Для заданного взвешенного графа <tex>G = (V, E)</tex> алгоритм находит кратчайшие пути из заданной вершины <tex> s </tex> до всех остальных вершин.<br> | ||
Строка 4: | Строка 6: | ||
==Введение== | ==Введение== | ||
− | :Сначала стоит вспомнить формулу для | + | :Сначала стоит вспомнить формулу для количества путей длины <tex>k</tex>. |
::<tex> d[k][u] = \sum\limits_{v : vu \; \in E} d[k-1][v] </tex> | ::<tex> d[k][u] = \sum\limits_{v : vu \; \in E} d[k-1][v] </tex> | ||
:Теперь перепишем ее для пути кратчайшей длины. <tex>s</tex> {{---}} стартовая вершина. | :Теперь перепишем ее для пути кратчайшей длины. <tex>s</tex> {{---}} стартовая вершина. | ||
::<tex> d[k][u] = \min\limits_{v : vu \; \in E}(d[k-1][v] \: + \: \omega[uv])</tex>, при этом <tex>d[0][s] = 0</tex>, а <tex>d[0][u] = +\inf </tex> | ::<tex> d[k][u] = \min\limits_{v : vu \; \in E}(d[k-1][v] \: + \: \omega[uv])</tex>, при этом <tex>d[0][s] = 0</tex>, а <tex>d[0][u] = +\inf </tex> | ||
+ | |||
+ | {{Лемма | ||
+ | |statement=Если существует кратчайший путь от <tex>s</tex> до <tex>t</tex>,<br> то <tex> \rho(s, \, t) \: = \: \min\limits_{k = 0..n-1} d[k][t]</tex> | ||
+ | |proof= | ||
+ | }} | ||
==Псевдокод== | ==Псевдокод== | ||
:Используя приведенные формулы, алгоритм можно реализовать методом динамического программирования. | :Используя приведенные формулы, алгоритм можно реализовать методом динамического программирования. | ||
− | '''for''' <tex>(k = 0..n-2)</tex> | + | '''for''' <tex>(k = 0 \; .. \; n-2)</tex> |
'''for''' <tex>(v \in V)</tex> | '''for''' <tex>(v \in V)</tex> | ||
'''for''' <tex>(u : vu \; \in E)</tex> | '''for''' <tex>(u : vu \; \in E)</tex> | ||
− | <tex>d[k][u] \gets \min(d[k | + | <tex>d[k+1][u] \gets \min(d[k][u], \; d[k][v] + \omega(u,v))</tex> |
:Также релаксацию можно свести к одномерному случаю (одномерный массив будем обозначать <tex>d'</tex>): | :Также релаксацию можно свести к одномерному случаю (одномерный массив будем обозначать <tex>d'</tex>): | ||
Строка 21: | Строка 28: | ||
==Корректность алгоритма Форда-Беллмана== | ==Корректность алгоритма Форда-Беллмана== | ||
+ | |||
+ | {{Лемма | ||
+ | |statement=Пусть <tex>G = (V, E) </tex> — взвешенный ориентированный граф, <tex> s </tex> — стартовая вершина.<br>Тогда после завершения <tex>k</tex> итераций цикла <tex>for(k)</tex> выполняется неравенство <tex> \rho(s, u) \leqslant d'[u] \leqslant \min\limits_{i = 0..k} d[i][u]</tex>. | ||
+ | |proof=: Воспользуемся индукцией по <tex>k</tex>: | ||
+ | |||
+ | : '''База индукции.''' При <tex>k = 0</tex> выполнено: <tex>\rho(s, u) \leqslant +\inf \leqslant +\inf </tex> | ||
+ | : '''Индукционный переход.''' | ||
+ | ::Сначала докажем, что <tex> \rho(s, u) \leqslant d'[u]</tex>. | ||
+ | ::Предположим, что <tex>d'[u] + \omega(vu) \gtr \omega(Path(s \to v) \circ (vu))</tex> | ||
+ | |||
+ | }} | ||
+ | |||
:В этом алгоритме используется релаксация, в результате которой <tex>d[v]</tex> уменьшается до тех пор, пока не станет равным <tex>\delta(s, v)</tex>. <br> | :В этом алгоритме используется релаксация, в результате которой <tex>d[v]</tex> уменьшается до тех пор, пока не станет равным <tex>\delta(s, v)</tex>. <br> | ||
:<tex>d[v]</tex> - оценка веса кратчайшего пути из вершины <tex>s</tex> в каждую вершину <tex>v \in V</tex>.<br> | :<tex>d[v]</tex> - оценка веса кратчайшего пути из вершины <tex>s</tex> в каждую вершину <tex>v \in V</tex>.<br> |
Версия 23:09, 27 февраля 2012
Эта статья находится в разработке!
Содержание
Алгоритм
- Для заданного взвешенного графа
- В случае когда в графе содержатся отрицательные циклы достижимые из алгоритм сообщает, что кратчайших путей не существует.
Введение
- Сначала стоит вспомнить формулу для количества путей длины
- Теперь перепишем ее для пути кратчайшей длины.
- , при этом , а
— стартовая вершина.
Лемма: |
Если существует кратчайший путь от до ,то |
Псевдокод
- Используя приведенные формулы, алгоритм можно реализовать методом динамического программирования.
forfor for
- Также релаксацию можно свести к одномерному случаю (одномерный массив будем обозначать ):
Корректность алгоритма Форда-Беллмана
Лемма: |
Пусть — взвешенный ориентированный граф, — стартовая вершина.Тогда после завершения итераций цикла выполняется неравенство . |
Доказательство: |
|
- В этом алгоритме используется релаксация, в результате которой
- - фактический вес кратчайшего пути из в вершину .
Лемма: |
Пусть — взвешенный ориентированный граф, — стартовая вершина.Тогда после завершения итераций цикла для всех вершин, достижимых из , выполняется равенство . |
Доказательство: |
|
Теорема: |
Пусть - взвешенный ориентированный граф, — стартовая вершина.Если граф не содержит отрицательных циклов, достижимых из вершины , то алгоритм возвращает и для всех . Если граф содержит отрицательные циклы, достижимые из вершины , то алгоритм возвращает |
Доказательство: |
|
Сложность
- Инициализация занимает
Итого алгоритм Беллмана-Форда работает за времени. времени, каждый из проходов требует времени, обход по всем ребрам для проверки наличия отрицательного цикла занимает времени.
Источники
- Кормен, Т., Лейзерсон, Ч., Ривест, Р., Штайн, К. Алгоритмы: построение и анализ / пер. с англ. — изд. 2-е — М.: Издательский дом «Вильямс», 2009. — с.672 — 676. — ISBN 978-5-8459-0857-5.
- Алгоритм Форда-Беллмана