МЕТОДЫ ОПРЕДЕЛЕНИЯ КРАТЧАЙШЕГО ПУТИ МЕЖДУ ВЕРШИНАМИ ГРАФА

Анализ алгоритмов, применяемых в настоящее время для поиска кратчайших путей между вершинами графа, позволил выявить алгоритмы Уоршолла, Дейкстры, Форда [1]. Все алгоритмы хаpaктеризуются разными вычислительными затратами и позволяют решать поставленную задачу, но наиболее эффективным считается алгоритм Дейкстры, предложенный в 1959 году.
Перед началом выполнения алгоритма все вершины и дуги не отмечены. Каждой вершине в ходе выполнения алгоритма присваивается число d(xi), равное длине кратчайшего пути из xi в xj, включающего только отмеченные вершины.
Выполняется присвоение начальных значений, для чего необходимо обозначить d(xi) пометку исходной вершины и считать, что d(xi) = 0. Отметить постоянной пометкой исходную вершину xi и положить y = xi, где y - последняя из отмеченных вершин. Остальные вершины имеют временные пометки и считать, что для xj ≠ y d(xj) = ∞. Алгоритм итерационный. Каждая итерация состоит из ряда шагов. Алгоритм Дейкстры рассмотрен на примере взвешенного графа (рис. 1,a). Матрица весов дуг приведена на рис. 1,b. Требуется найти кратчайший путь от вершины x1 до вершины x6.
Рис. 1. Пример поиска кратчайшего пути: a - граф; б - матрица весов дуг
Выполняется присвоение начальных значений: d(x1) = 0; xi ≠ x1 d(xi) = ∞.
Для каждой итерации, в соответствующую строку таблицы заносится отмеченная вершина и текущие значения d(xi). Для 1-й итерации будем иметь:
y = x1. Г(x1) = {x2, x3, x4}.
Для всех вершин, входящих в Г(x1), пометки которых временные, необходимо пересчитать d(xi) в виде:
d(x2) = min [d(x2), d(x1) + t(x1, x2)] = min [∞, 0 + 4] = 4.
Аналогично для d(x3), d(x4). Массив временных пометок будет иметь вид: {d(x2), d(x3), d(x4)} = 4, 3, 7}.
Поскольку величина d(x3) = 3 является минимальной, то вершина x3 отмечается x3*. Также отмечается и дуга (x1, x3)*. Наименьшее из значений d(xi) среди неотмеченных вершин в таблице выделено полужирным шрифтом.
Текущее дерево кратчайших путей состоит из дуги (x1, x3)* (рис. 2,а).
Таким образом, выполнив еще 4 итерации, получим окончательно построенное дерево кратчайших путей, которое состоит из дуг (x1, x3)*, (x1, x2)*, (x3, x5)*, (x2, x4)* и (x5, x6)* (рис. 2,д).
а б в г д
Рис. 2. Текущие деревья кратчайшего пути ─ a, б, в, г и окончательно построенное дерево кратчайших путей ─ д
Вычисления по алгоритму Дейкстры
|
Итерация |
Отмеченная вершина |
Расстояние до вершины |
|||||
|
d(x1) |
d(x2) |
d(x3) |
d(x4) |
d(x5) |
d(x6) |
||
|
Начало |
x1 |
0 |
∞ |
∞ |
∞ |
∞ |
∞ |
|
1 |
x1* |
0 |
4 |
3 |
7 |
∞ |
∞ |
|
2 |
x3* |
0 |
4 |
3* |
7 |
6 |
∞ |
|
3 |
x2* |
0 |
4* |
3* |
7 |
6 |
∞ |
|
4 |
x5* |
0 |
4* |
3* |
7 |
6* |
8 |
|
5 |
x4* |
0 |
4* |
3* |
7* |
6* |
8 |
Кратчайший путь, соединяющий вершину x1 с вершиной x6, состоит из дуг (x1, x2), (x2, x5) и (x5, x6) имеет длину 4 + 2 + 2 = 8. Это не единственный кратчайший путь между вершинами x1 и x6. Путь, состоящий из дуг (x1, x3), (x3, x5) и (x5, x6) имеет длину 3 + 3 + 2 = 8 и также является кратчайшим путем между вершинами x1 и x6.
Существуют алгоритмы более эффективные, чем процеДypa многократного повторения алгоритма Дейкстры. Эти алгоритмы принадлежат Флойду и Данцигу. В обоих алгоритмах для длин дуг допускаются отрицательные значения, однако не допускается наличие контуров отрицательной длины.
Как видно из описания алгоритмов поиска кратчайших путей, в основном они состоят из операций двух типов: операции сложения и операции сравнения по минимуму. При анализе вычислительной сложности любого из этих алгоритмов обычно предполагается, что для выполнения обеих операций требуется одинаковое время.
Список литературы
1. Майника Э. Алгоритмы оптимизации на сетях и графах. - М.: Мир, 1981. - 324 с.
2. Новиков Ф.А. Дискретная математика для программистов. - СПб: Питер, 2000. - 304 с.
3. Хаггарти Р. Дискретная математика для программистов. - М.: Техносфера, 2005. - 400 с.
Статья в формате PDF
202 KB...
02 07 2026 16:26:14
Статья в формате PDF
395 KB...
01 07 2026 12:52:46
Статья в формате PDF
110 KB...
30 06 2026 3:55:42
Статья в формате PDF 130 KB...
29 06 2026 19:25:23
Статья в формате PDF
209 KB...
28 06 2026 8:26:44
Статья в формате PDF
100 KB...
27 06 2026 11:55:39
Статья в формате PDF
429 KB...
26 06 2026 0:27:48
Статья в формате PDF
124 KB...
25 06 2026 17:30:34
Статья в формате PDF
190 KB...
24 06 2026 4:35:24
Статья в формате PDF
205 KB...
23 06 2026 9:33:56
Статья в формате PDF
111 KB...
22 06 2026 18:48:16
Статья в формате PDF
161 KB...
21 06 2026 3:52:22
Статья в формате PDF
275 KB...
20 06 2026 9:42:41
Статья в формате PDF
124 KB...
19 06 2026 18:27:24
Статья в формате PDF
128 KB...
16 06 2026 10:20:50
Статья в формате PDF
111 KB...
15 06 2026 4:54:17
Статья в формате PDF
167 KB...
14 06 2026 6:52:54
Статья в формате PDF
214 KB...
13 06 2026 16:41:44
Статья в формате PDF
121 KB...
12 06 2026 6:19:40
С использованием инструмента «Bilateral Trade» базы данных Trade Map проделаны матричный анализ взаимной торговли в системе стран БРИКС + Иран за 2001 и 2010 гг. Расчеты показали на существенную трaнcформацию взаимной торговли в системе рассматриваемых стран, в которой Россия значительно ухудшила свои позиции, а Бразилия и Китай – улучшили. Показано также, что Иран гораздо лучше интегрирован во взаимную торговлю со странами БРИКС по сравнению с ЮАР, что даёт ему весомый аргумент для вступления в это объединение стран.
...
11 06 2026 3:19:58
Статья в формате PDF
126 KB...
10 06 2026 8:31:23
09 06 2026 23:44:18
Статья в формате PDF
161 KB...
07 06 2026 0:47:55
Статья в формате PDF
251 KB...
06 06 2026 23:53:31
Статья в формате PDF
111 KB...
05 06 2026 2:19:54
Статья в формате PDF
135 KB...
04 06 2026 16:29:44
Статья в формате PDF
134 KB...
03 06 2026 2:40:43
Статья в формате PDF
127 KB...
02 06 2026 2:38:18
Статья в формате PDF
161 KB...
01 06 2026 3:27:28
Статья в формате PDF
115 KB...
31 05 2026 16:28:15
Статья в формате PDF
119 KB...
30 05 2026 6:57:36
Статья в формате PDF
147 KB...
29 05 2026 16:26:41
Статья в формате PDF
116 KB...
27 05 2026 18:51:11
Статья в формате PDF
104 KB...
26 05 2026 21:47:53
Статья в формате PDF
125 KB...
25 05 2026 13:51:40
Статья в формате PDF
117 KB...
24 05 2026 9:56:12
Еще:
Поддержать себя -1 :: Поддержать себя -2 :: Поддержать себя -3 :: Поддержать себя -4 :: Поддержать себя -5 :: Поддержать себя -6 :: Поддержать себя -7 :: Поддержать себя -8 :: Поддержать себя -9 :: Поддержать себя -10 :: Поддержать себя -11 :: Поддержать себя -12 :: Поддержать себя -13 :: Поддержать себя -14 :: Поддержать себя -15 :: Поддержать себя -16 :: Поддержать себя -17 :: Поддержать себя -18 :: Поддержать себя -19 :: Поддержать себя -20 :: Поддержать себя -21 :: Поддержать себя -22 :: Поддержать себя -23 :: Поддержать себя -24 :: Поддержать себя -25 :: Поддержать себя -26 :: Поддержать себя -27 :: Поддержать себя -28 :: Поддержать себя -29 :: Поддержать себя -30 :: Поддержать себя -31 :: Поддержать себя -32 :: Поддержать себя -33 :: Поддержать себя -34 :: Поддержать себя -35 :: Поддержать себя -36 :: Поддержать себя -37 :: Поддержать себя -38 ::