Алгоритм Форда-Белмана.
Шаг 1. Составляется матрица длин дуг и таблица величин z . Если z = ∞,
то вершина vj не достижима из v . В этом случае работа алгоритма заканчивается.
Шаг 2. Величина z выражает длину любого минимального пути из v в
vj. Определим минимальное число m ≥ 1, при котором выполняется равенство
z = z . По определению чисел z получаем, что m – минимальное число дуг в пути среди всех минимальных путей из v в vj.
Шаг 3. Последовательно определяем номера i , …, i такие, что
(3.15)
. . . . . . . . . . . . . . .
Тогда v vim … vi2 v – искомый минимальный путь из v в vj.
Пример. Найти минимальный путь в орграфе рис.3.32 из вершины v в вершину v .
Рис. 3.32
Шаг 1. Составляем матрицу длин дуг данного орграфа, которая представлена в табл.3.7.
Таблица 3.7
| v1 | v2 | v3 | v4 | v5 | v6 |
v1 | ∞ | ∞ | 5 | 5 | 2 | 12 |
v2 | ∞ | ∞ | ∞ | ∞ | ∞ | 2 |
v3 | ∞ | 2 | ∞ | ∞ | ∞ | ∞ |
v4 | ∞ | 2 | ∞ | ∞ | ∞ | ∞ |
v5 | ∞ | ∞ | 1 | 2 | ∞ | ∞ |
v6 | ∞ | ∞ | ∞ | ∞ | ∞ | ∞ |
Далее составляем таблицу величин z , которая представлена в табл. 3.8. Первый столбец этой таблицы ( k = 0 ) будет состоять из следующих элементов
z = 0, z = z = z = z = z = ∞.
Затем определяем элементы второго столбца ( k = 1 ).
По формулам (3.14) получим
z = min [0, min( z + C )].
1≤j≤6
В этом выражении min (z + C ) = ∞, т.к. C = ∞ (см. первый столбец табл.3.8). 1≤j≤6
Следовательно, все элементы z = 0, т.е. все элементы первой строки равны 0. Остальные элементы второго столбца определяются формулой (3.13), которая будет иметь вид
z = min (z + C ).
1≤j≤6
Минимум правой части этой формулы будет при j = 1 т.к. все z = ∞ кроме z = 0. Следовательно, искомые элементы будут вычисляться по формуле
z =C и будут равны z = , z = 5, z = 5, z = 2, z = 12.
Далее по формуле (3.13) вычисляем элементы третьего столбца ( k=2 ), начиная со второго. z = min ( z + C ) = 7, z = 3, z = 4, z = 2, z = 12.
1≤j≤6
Аналогично определяем элементы остальных строк.
Таблица 3.8
-
i
z
z
z
z
z
z
1
0
0
0
0
0
0
2
7
5
5
5
3
5
3
3
3
3
4
5
4
4
4
4
5
2
2
2
2
2
6
12
1 2
9
7
7
Из табл.3.8 видно, что z = 7 ≠ ., следовательно, вершина v достижима из вершины v .
Шаг 2. Определяем минимальное число m ≥ 1, из равенства z = z . Из табл.3.8 видно, что m = 4, т.е. минимальное число дуг в пути среди всех минимальных путей из вершины v в вершину v равно 4.
Шаг 3. Последовательно из выражений (3.10) определяем номера
i , i , i , i , i .
Первое равенство в (3.15) будет иметь вид
z + C = z = 7.
Сравнивая четвертый столбец табл.3.8 и шестой столбец табл.3.7 видим, что это равенство выполняется при i = 2, т.е.
z + C = 5 + 2 = 7.
Запишем второе равенство из (3.15), которое будет иметь вид
z + C = z = 5.
Сравнивая третий столбец табл.3.8 и второй столбец табл.3.7 видим, что это равенство выполняется при i = 3, т.е.
z + C = 3 + 2 = 5.
Следующее равенство из (3.15) имеет вид
z + C = z = 3 и выполняется при i = 5.
Последнее равенство будет иметь вид
z + C = z = 2 и выполняется при i = 1.
Тогда искомый минимальный путь из вершины v в вершину v будет следующий v v v v v . Он содержит минимальное число дуг среди всех возможных путей из v в v .
- Двузначная логика ………………………………………………5
- 2.5. Полнота и замкнутость……. ……………………………………….........50
- Комбинаторика…………………………………………………….87
- 1. Двузначная логика
- 1.1. Функции алгебры логики
- 1.2. Суперпозиция и формулы алгебры логики
- 1.3. Булева алгебра
- 1.4. Алгебра Жегалкина
- Нормальные формы логических функций
- Приведение логической формулы к днф
- Приведение днф функции к кнф
- Приведение кнф функции к днф
- 1.6. Минимизация функций
- 1.7. Полнота и замкнутость
- Закон двойственности
- 2.1. Элементарные функции
- 2.2. Основные свойства элементарных функций
- 2.3. Основные формы функций k – значных логик
- 2.4. Представление функций полиномами
- 2.5. Полнота и замкнутость
- 3. Элементы теории графов
- 3.1. Способы задания графов
- 3.2. Изоморфизм. Плоские графы. Реализуемость в r
- 3.3. Пути. Цепи. Циклы. Расстояния
- 3.4. Подграфы. Связность
- 3.5. Поиск путей в графах и минимальных путей в орграфах
- 3.6. Деревья и леса
- 3.7. Взвешенные графы
- Алгоритм Форда-Белмана.
- 4. Комбинаторика
- 4.1. Мощность множества. Правила суммы, произведения, степени
- 4.2. Размещения. Перестановки. Сочетания
- 4.3. Производящие функции