Алгоритм Дейкстры
Версия от 07:29, 6 декабря 2010; Vladimir.nesmelov (обсуждение | вклад)
Эта статья находится в разработке!
В ориентированном взвешанном графе
, вес рёбер которого неотрицателен и определяется весовой функцией , Алгоритм Дейкстры находит длину кратчайшего пути из одной вершины до всех остальных.Алгоритм
В алгоритме поддерживается множество вершин
, для которых уже вычислены кратчайшие пути к ним из вершины . На каждой итерации основного цикла выбирается вершина , которой на текущий момент соответствует минимальная оценка кратчайшего пути. Вершина добавляется в множество и производится релаксация всех исходящих из неё рёбер.Псевдокод
Dijkstra(, , ) while do argmin( ) for do relax( , , )
Обоснование корректности работы
Теорема: |
После окончания работы алгоритма Дейкстры для всех вершин будет выполняться равенство |
Доказательство: |
Рассмотрим инвариант основного цикла: в начале каждой итерации для всех вершин выполняетсяИнициализация. Изначально множество Сохранение. пусто, инвариант выполняется. |
Оценка сложности
Литература
- Кормен Т. Х., Лейзерсон Ч. И., Ривест Р. Л., Штайн К. Алгоритмы: построение и анализ, 2-е издание. Пер. с англ. — М.:Издательский дом "Вильямс", 2010. — 1296 с.: ил. — Парал. тит. англ. — ISBN 978-5-8459-0857-5 (рус.)