Алгоритм Дейкстры — различия между версиями
м |
|||
Строка 1: | Строка 1: | ||
− | + | {{Задача | |
+ | |definition=Для заданного взвешенного графа <tex>G = (V, E)</tex> найти кратчайшие пути из заданной вершины <tex> s </tex> до всех остальных вершин. Веса всех рёбер неотрицательны. | ||
+ | }} | ||
== Алгоритм == | == Алгоритм == | ||
+ | В [[Ориентированный граф|ориентированном]] взвешенном [[Основные определения: граф, ребро, вершина, степень, петля, путь, цикл|графе]] <tex>G = (V, E)</tex>, вес [[Основные определения: граф, ребро, вершина, степень, петля, путь, цикл|рёбер]] которого неотрицателен и определяется весовой функцией <tex>w : E \to \mathbb{R}</tex>, алгоритм Дейкстры находит длины кратчайших [[Основные определения: граф, ребро, вершина, степень, петля, путь, цикл|путей]] из заданной [[Основные определения: граф, ребро, вершина, степень, петля, путь, цикл|вершины]] <tex>s</tex> до всех остальных.<br> | ||
В алгоритме поддерживается множество вершин <tex>U</tex>, для которых уже вычислены длины кратчайших путей до них из <tex>s</tex>. На каждой итерации основного цикла выбирается вершина <tex> u \notin U</tex>, которой на текущий момент соответствует минимальная оценка кратчайшего пути. Вершина <tex>u</tex> добавляется в множество <tex>U</tex> и производится релаксация всех исходящих из неё рёбер. | В алгоритме поддерживается множество вершин <tex>U</tex>, для которых уже вычислены длины кратчайших путей до них из <tex>s</tex>. На каждой итерации основного цикла выбирается вершина <tex> u \notin U</tex>, которой на текущий момент соответствует минимальная оценка кратчайшего пути. Вершина <tex>u</tex> добавляется в множество <tex>U</tex> и производится релаксация всех исходящих из неё рёбер. | ||
== Псевдокод == | == Псевдокод == | ||
− | < | + | '''func''' dijkstra(s)''':''' |
− | + | '''for''' i = 0 '''to''' n <font color="green">// n {{---}} количество вершин в графе</font> | |
− | + | d[v] = <tex>\infty</tex> | |
− | < | + | used[v] = ''false'' |
− | < | + | d[s] = 0 |
− | + | '''for''' i = 0 '''to''' n | |
− | : < | + | v = ''null'' |
− | + | '''for''' j = 0 '''to''' n <font color="green">// найдем вершину с минимальным расстоянием</font> | |
− | + | '''if''' !used[j] '''and''' (v == ''null'' '''or''' d[j] < d[v]) | |
− | + | v = j | |
+ | '''if''' d[v] == <tex>\infty</tex> | ||
+ | '''break''' | ||
+ | used[v] = ''true'' | ||
+ | '''for''' e : исходящие из ''v'' рёбра <font color="green">// произведём релаксацию по всем рёбрам, исходящим из ''v''</font> | ||
+ | '''if''' d[v] + e.len < d[e.to] | ||
+ | d[e.to] = d[v] + e.len | ||
== Обоснование корректности == | == Обоснование корректности == |
Версия 18:41, 19 декабря 2015
Задача: |
Для заданного взвешенного графа | найти кратчайшие пути из заданной вершины до всех остальных вершин. Веса всех рёбер неотрицательны.
Алгоритм
В ориентированном взвешенном графе , вес рёбер которого неотрицателен и определяется весовой функцией , алгоритм Дейкстры находит длины кратчайших путей из заданной вершины до всех остальных.
В алгоритме поддерживается множество вершин , для которых уже вычислены длины кратчайших путей до них из . На каждой итерации основного цикла выбирается вершина , которой на текущий момент соответствует минимальная оценка кратчайшего пути. Вершина добавляется в множество и производится релаксация всех исходящих из неё рёбер.
Псевдокод
func dijkstra(s): for i = 0 to n // n — количество вершин в графе d[v] =used[v] = false d[s] = 0 for i = 0 to n v = null for j = 0 to n // найдем вершину с минимальным расстоянием if !used[j] and (v == null or d[j] < d[v]) v = j if d[v] == break used[v] = true for e : исходящие из v рёбра // произведём релаксацию по всем рёбрам, исходящим из v if d[v] + e.len < d[e.to] d[e.to] = d[v] + e.len
Обоснование корректности
Теорема: |
Пусть — ориентированный взвешенный граф, вес рёбер которого неотрицателен, — стартовая вершина.
Тогда после выполнения алгоритма Дейкстры для всех , где — длина кратчайшего пути из вершины в вершину |
Доказательство: |
Докажем по индукции, что в момент посещения любой вершины , .
|
Оценка сложности
Основной цикл выполняется
раз. Релаксация выполнится всего раз. В реализации алгоритма присутствует функция выбора вершины с минимальным значением , асимптотика её работы зависит от реализации.Таким образом:
Структура данных | Время работы |
---|---|
Наивная реализация | |
Двоичная куча | |
Фибоначчиева куча |
Источники
- Кормен, Томас Х., Лейзерсон, Чарльз И., Ривест, Рональд Л., Штайн Клиффорд Алгоритмы: построение и анализ, 2-е издание. Пер. с англ. — М.:Издательский дом "Вильямс", 2010. — 1296 с.: ил. — Парал. тит. англ. — ISBN 978-5-8459-0857-5 (рус.)
- Википедия — свободная энциклопедия