РЕШЕНИЕ ЗАДАЧИ О КОММИВОЯЖЕРЕ МЕТОДОМ ВЕТВЕЙ И ГРАНИЦ. ПРИМЕРЫ - Задача коммивояжера

Рассмотрим конкретный пример реализации метода ветвей и границ для решения задачи о коммивояжере.

Итак, требуется найти легчайший простой основный ориентированный цикл в полном взвешенном ориентированном графе на пяти вершинах со следующей весовой матрицей:

Таблица 2

1

2

3

4

5

1

9

8

4

10

2

6

4

5

7

3

5

3

6

2

4

1

7

2

8

5

2

4

5

2

Верхняя строка и левый столбец, выделенные затемненным фоном, содержат номера вершин графа; символ, стоящий на главной диагонали, означает, естественно, отсутствие ребер-петель (начинающихся и заканчивающихся в одной и той же вершине); кроме того, символ здесь и всюду в дальнейшем обозначает "компьютерную бесконечность", т. е. самое большое из возможных в рассмотрении чисел; считается, что + любое число =.

Подсчитаем () в нашем примере. Для этого выполним приведение матрицы весов; сначала - по строкам:

Таблица 3

1

2

3

4

5

1

9

8

4

10

4

min в строке 1

2

6

4

5

7

4

min в строке 2

3

5

3

6

2

2

min в строке 3

4

1

7

2

8

1

min в строке 4

5

2

4

5

2

2

min в строке 5

Результат приведения по строкам:

Таблица 4

1

2

3

4

5

1

5

4

0

6

2

2

0

1

3

3

3

1

4

0

4

0

6

1

7

5

0

2

3

0

Определим константы приведения по столбцам:

Таблица 5

1

2

3

4

5

1

5

4

0

6

2

2

0

1

3

3

3

1

4

0

4

0

6

1

7

5

0

2

3

0

0

1

0

0

0

Min в

Столбце 1

Min в

Столбце 2

Min в

Столбце 3

Min в

Столбце 4

Min в

Столбце 5

Результат приведения матрицы:

Таблица 6

1

2

3

4

5

1

4

4

0

6

2

2

0

1

3

3

3

0

4

0

4

0

5

1

7

5

0

1

3

0

Сумма констант приведения ()=4+4+2+1+2+1=14.

Обозначим эту матрицу через M1; найдем в ней самый тяжелый нуль. Для этого запишем эту матрицу еще раз, указывая рядом с каждым нулем в скобках его вес:

Таблица 7

1

2

3

4

5

1

4

4

0(4)

6

2

2

0(2)

1

3

3

3

0(1)

4

0(3)

4

0(1)

5

1

7

5

0(0)

1

3

0(0)

Самым тяжелым оказывается нуль в клетке (1,4). Следовательно, множество разбивается на (все циклы, проходящие через ребро (1,4)) и (все циклы, не проходящие через ребро (1,4)).

Построим для множества соответствующую ему матрицу и значение оценочной функции.

Условимся о следующем действии: перед тем, как в очередной матрице вычеркнуть строку и столбец, в ней надо заменить на числа во всех тех клетках, которые соответствуют ребрам, заведомо не принадлежащим тем гамильтоновым циклам, которые проходят через уже отобранные ранее ребра.

Учитывая это напоминание, элемент с номером (4,1) заменим на и вычеркнем строку номер 1 и столбец номер 4:

Таблица 8

1

2

3

5

2

2

0

3

3

3

0

0

4

5

1

7

5

0

1

3

Приведем теперь эту матрицу:

Таблица 9

1

2

3

5

2

2

0

3

3

3

0

0

4

4

0

6

5

0

1

3

Это - матрица M1,1; сумма констант приведения здесь равна 1, поэтому 14+1= 15.

Для M1,2 заменяем на элемент (1,4) в M1:

Таблица 10

1

2

3

4

5

1

4

4

6

2

2

0

1

3

3

3

0

4

0

4

0

5

1

7

5

0

1

3

0

После этого приводим полученную матрицу:

Таблица 11

1

2

3

4

5

1

0

0

2

2

2

0

1

3

3

3

0

4

0

4

0

5

1

7

5

0

1

3

0

Это - матрица M1,2; сумма констант последнего приведения равна 4, так что 14+4=18. Следовательно, дальнейшей разработке подвергается множество.

Вот веса нулей матрицы M1,1 (они указаны в скобках):

Таблица 12

1

2

3

5

2

2

0(2)

3

3

3

0(1)

0(3)

4

4

0(4)

6

5

0(3)

1

3

Самым тяжелым является нуль с номером (4,3), так что теперь следует рассматривать множества и.

Обратимся к первому из них.

Условимся о следующем действии: перед тем, как в очередной матрице вычеркнуть строку и столбец, в ней надо заменить на числа во всех тех клетках, которые соответствуют ребрам, заведомо не принадлежащим тем гамильтоновым циклам, которые проходят через уже отобранные ранее ребра.

Следовательно, клетки с номерами (4,2), (4,5) и (3,1) надо заполнить символом ; после этого строку номер 4 и столбец номер 3 следует вычеркнуть; получим:

Таблица 13

1

2

5

2

2

3

3

0

0

5

0

1

Приведение этой матрицы:

Таблица 14

1

2

5

2

0

1

3

0

0

5

0

1

Для оценочной функции: =15+2=17.

Матрица для множества :

Таблица 15

1

2

3

5

2

2

0

3

3

3

0

0

4

4

6

5

0

1

3

Результат ее приведения:

Таблица 16

1

2

3

5

2

2

0

3

3

3

0

0

4

0

2

5

0

1

3

Оценочная функция: =15+4=19. Следовательно, дальнейшей разработке подлежит. "Взвешиваем" нули:

Таблица 17

1

2

5

2

0(1)

1

3

0(1)

0(1)

5

0(1)

1

Выбираем любую из соответствующих клеток; для определенности - клетку (2,1).

Теперь речь пойдет о множествах и.

Условимся о следующем действии: перед тем, как в очередной матрице вычеркнуть строку и столбец, в ней надо заменить на числа во всех тех клетках, которые соответствуют ребрам, заведомо не принадлежащим тем гамильтоновым циклам, которые проходят через уже отобранные ранее ребра.

Поэтому для первого множества положим в последней матрице элемент с номером (3,2) равным, вычеркнем строку номер 2 и столбец номер 1:

Таблица 18

2

5

3

0

5

1

Приведем эту матрицу:

Таблица 19

2

5

3

0

5

0

Получаем для оценочной функции: =17+1=18.

Для множества матрица такова:

Таблица 20

1

2

5

2

1

3

0

0

5

0

1

Приведение этой матрицы дает:

Таблица 21

1

2

5

2

0

3

0

0

5

0

1

Для оценочной функции: =17+1=18.

Получилось, что для дальнейшей разработки можно брать любое из множеств и. В первом случае уже получена матрица размером 22; ее нулевые клетки дают те ребра, которые с найденными ранее составляют обход коммивояжера, причем вес этого обхода равен значению оценочной функции - 18. Вот этот обход:

(1,4)(4,3)(2,1)(5,2)(3,5) или 143521.

Найденный рекорд на самом деле является искомым оптимумом, потому что значения оценочной функции на всех оборванных ветвях (на границах) больше или равны весу рекорда.

При ином варианте выборов по ходу разбиений можно было получить другой оптимум: 143251.

ПРАКТИЧЕСКОЕ ЗАДАНИЕ

Требуется найти легчайший простой основный ориентированный цикл в полном взвешенном ориентированном графе на четырех вершинах (рис. 2):

ориентированный граф задачи коммивояжера

Рис. 2. Ориентированный граф задачи коммивояжера

Попробуем решить данную задачу методом "жадный алгоритм".

Из пункта 1 существует только один путь - путь к пункту 2, стоимость пути равна 78. Из пункта 2 существует только один путь - путь к пункту 3, стоимость пути равна 81. Из пункта 3 существует два пути - путь к пункту 1 и путь к пункту 4. Выберем самый кратчайший путь - это путь к пункту 4, стоимость пути равна 16. Из пункта 4 существует два пути - путь к пункту 1 и путь к пункту 2. Так как в пункте 2 мы уже были, то идем в пункт 1, стоимость пути равна 25.

Полный обход коммивояжера, исходя из предыдущего решения, равен 12341, а сумма пути равна: 78+81+16+25 = 200.

Похожие статьи




РЕШЕНИЕ ЗАДАЧИ О КОММИВОЯЖЕРЕ МЕТОДОМ ВЕТВЕЙ И ГРАНИЦ. ПРИМЕРЫ - Задача коммивояжера

Предыдущая | Следующая