logo
Лекции ДМ

Минимальные маршруты в нагруженных графах

Граф G(V, X) называется нагруженным, если на множестве ребер графа задана функция, называемая весовой, которая ставит в соответствие каждому ребру х Х графа некоторое число l(x). Значение l(x) называется длиной дуги.

Величине l(x) можно придать разный смысл: затраты на транспортировку, время проезда, расстояние между пунктами, расход бензина и т.д.

Сумма длин ребер, входящих в маршрут, называется длиной маршрута.

Заметим, что если для всех х  Х l(x) = 1, то граф можно рассматривать как ненагруженный.

Маршрут в графе G(V, X) из вершины v в вершину w (vw), называется минимальным, если он имеет минимальную длину среди всех маршрутов в графе G(V, X) из вершины v в вершину w.

Ограничимся графами, для которых l(x)>0.

При поиске минимального маршрута в нагруженном графе с l(x)>0

воспользуемся таким же утверждением, что и для ненагруженного графа, а именно:

любой минимальный маршрут является простой цепью.

Рассмотрим теперь задачу поиска минимального маршрута в нагруженном графе.

Пусть граф G(V,X) нагруженный, число вершин n  2, необходимо построить минимальный маршрут из v1 в vn.

Приведем алгоритм.

Шаг 1. Каждой вершине присвоить индекс (vi): (v1) = 0, (vi) = , i  1. окрасить вершину v1 и положить v = v1.

Шаг 2. Для каждой неокрашенной вершины vj изменить индекс по правилу:

(vj) = min {(vj), (v) + l(v, vj)}.

Окрасить ту из вершин, для которой (vj) окажется наименьшим.. окрасить также ребро, ведущее в выбранную на данном шаге вершину vj . Положить v = vj.

Шаг 3. Если v = vj , закончить процедуру, так как кратчайший маршрут из v1 в vn . если v  vn , то перейти к шагу 2.

Замечание. Шаг 2 невозможен, если все (vj)= . В этом случае вершина vn недостижима.

Применим изложенный алгоритм к заданному диаграммой графу. Найдем в нем кратчайший маршрут из v1 в v6.

Шаг 1. Окрасим вершину v1 . Присвоим вершинам индексы: (v1) =0, (v2) = (v3)=…= (vn)=. Полагаем v1 = v.

Шаг 2.

(v2) = min {, 0+4} = 4,

(v3) = min {, 0+7} = 7,

(v4) = min {, 0+3} = 3,

(v5) = min {, 0+} = ,

(v6) = min {, 0+} = .

Окрашиваем вершину v4 и ребро {v1, v4}.

Шаг 3. Так как вершина v6 не окрашена, выполняем шаг 2, полагая v = v4.

Шаг 2.

(v2) = min {4, 3+} = 4,

(v3) = min {7, 3+} = 7,

(v5) = min {, 3+3} = 6,

(v6) = min {, 3+} = .

Окрашиваем вершину v2 и ребро {v1, v2}.

Шаг 3. Так как вершина v6 не окрашена, выполняем шаг 2, полагая v = v2.

Шаг 2.

(v3) = min {7, 4+3} = 7,

(v5) = min {6, 4+2} = 6,

(v6) = min {, 4+} = .

Окрашиваем вершину v5 и ребро {v4, v5}.

Шаг 3. Так как вершина v6 не окрашена, выполняем шаг 2, полагая v = v5.

Шаг 2.

(v3) = min {7, 6+} = 7,

(v6) = min {, 6+2} = 8.

Окрашиваем вершину v3 и ребро {v1, v3}.

Шаг 3. Так как вершина v6 не окрашена, выполняем шаг 2, полагая v = v3.

Шаг 2.

(v6) = min {8, 7+2} = 8.

Окрашиваем вершину v6 и ребро {v5, v6}.

Так как вершина v6 окрашена, то работу прекращаем. Получили минимальный маршрут v1 v4 v5 v6 , длина которого равна 8 .

Заметим, что это в данном случае не единственный для вершин v1 и v6 минимальный маршрут, т.к. в алгоритме имелась возможность окрасить вместо ребра {v4, v5} ребро {v2, v5}, тогда бы получили другой маршрут той же длины.

Yandex.RTB R-A-252273-3
Yandex.RTB R-A-252273-4