Мегаобучалка Главная | О нас | Обратная связь


Пример применения алгоритма Дейкстры



2020-03-19 194 Обсуждений (0)
Пример применения алгоритма Дейкстры 0.00 из 5.00 0 оценок




 

Необходимо найти все кратчайшие пути от вершины №1 для графа, представленого на рисунке

 

 

Составим матрицу длин кратчайших дуг для данного графа.

 

тартовая вершина, от которой строится дерево кратчайших путей - вершина 1.

Задаем стартовые условия: d(1)=0, d(x)=∞

Окрашиваем вершину 1, y=1.

Находим ближайшую вершину к окрашенной нами, используя формулу: d(x)=min {d(x); d(y)+ ay,x}

 

d(2)=min {d(2); d(1)+a (1,2)}=min {∞; 0+10}=10(3)=min {d(3); d(1)+a (1,3)}=min {∞; 0+18}=18(4)=min {d(4); d(1)+a (1,4)}=min {∞; 0+8}=8(5)=min {d(5); d(1)+a (1,5)}=min {∞; 0+∞}=∞(6)=min {d(6); d(1)+a (1,6)}=min {∞; 0+∞}=∞

 

Минимальную длину имеет путь от вершины 1 до вершины 4 d(4)=8. Включаем вершину №4 в текущее ориентированноe дерево, а так же дугу ведущую в эту вершину. Согласно выражению это дуга (1,4)

 

d(2)=min {d(2); d(4)+a (4,2)}=min {10; 8+9}=10(3)=min {d(3); d(4)+a (4,3)}=min {18; 8+∞}=18(5)=min {d(5); d(4)+a (4,5)}=min {∞; 8+∞}=∞(6)=min {d(6); d(4)+a (4,6)}=min {∞; 8+12}=20

 

Минимальную длину имеет путь от вершины 1 до вершины 2 d(2)=10. Включаем вершину №2 в текущее ориентированноe дерево, а так же дугу ведущую в эту вершину. Согласно выражению это дуга (1,2)

 

d(3)=min {d(3); d(2)+a (2,3)}=min {18; 10+16}=18(5)=min {d(5); d(2)+a (2,5)}=min {∞; 10+21}=31(6)=min {d(6); d(2)+a (2,6)}=min {20; 10+∞}=20

 

Минимальную длину имеет путь от вершины 1 до вершины 3 d(3)=18. Включаем вершину №3 в текущее ориентированноe дерево, а так же дугу ведущую в эту вершину. Согласно выражению это дуга (1,3)


d(5)=min {d(5); d(3)+a (3,5)}=min {31; 18+15}=31

d(6)=min {d(6); d(3)+a (3,6)}=min {20; 18+∞}=20

 

Минимальную длину имеет путь от вершины 1 до вершины 6 d(6)=20. Включаем вершину №6 в текущее ориентированноe дерево, а так же дугу ведущую в эту вершину. Согласно выражению это дуга (4,6)

 

d(5)=min {d(5); d(6)+a (6,5)}=min {31; 20+23}=31

 

Минимальную длину имеет путь от вершины 1 до вершины 5 d(5)=31. Включаем вершину №5 в текущее ориентированноe дерево, а так же дугу ведущую в эту вершину. Согласно выражению это дуга (2,5)

Мы получили ориентированное дерево кратчайших путей начинающихся в вершине №1 для исходного графа.(1)=1 Длина маршрута L=0(2)=1-2 Длина маршрута L=10(3)=1-3 Длина маршрута L=18(4)=1-4 Длина маршрута L=8(5)=1-2-5 Длина маршрута L=31(6)=1-4-6 Длина маршрута L=20

 

Ориентированное дерево с корнем в вершине №1:

 


Алгоритм Флойда

 

Алгоритм Флойда является одним из методов поиска кратчайших путей в графе. В отличии от алгоритма Дейкстры, который позволяет при доведении до конца построить ориентированное дерево кратчайших путей от некоторой вершины, метод Флойда позволяет найти длины всех кратчайших путей в графе. Конечно эта задача может быть решена и многократным применением алгоритма Дейкстры (каждый раз последовательно выбираем вершину от первой до N-ной, пока не получим кратчайшие пути от всех вершин графа), однако реализация подобной процедуры потребовала бы значительных вычислительных затрат.

Прежде чем представлять алгоритмы, необходимо ввести некоторые обозначения. Перенумеруем вершины исходного графа целыми числами от 1 до N. Обозначим через di,jm длину кратчайшего пути из вершинм i в вершину j, который в качестве промежуточных может содержать только первые m вершин графа. Промежуточной вершиной пути является любая принадлежащая ему вершина, не совпадающая с его начальной или конечной вершинами. Если между вершинами i и j не существует ни одного пути указанного типа, то условно будем считать, что di,jm=∞. Из данного определения величин di, jm следует, что величина di,j0, представляет длину кратчайшего пути из вершины i в вершину j, не имеющего промежуточных вершин, т.е. длину кратчайшей дуги, соединяющей i с j (если такие дуги присутствуют в графе). для любой вершины i положим di,jm = 0. Отметим далее, что величина di, jmпредставляет длину кратчайшего пути между вершинами i и j.

Обозначим через Dm матрицу размера NxN, элемент (i, j) которой совпадает с di,jm. Если в исходном графе нам известна длина каждой дуги, то мы можем сформировать матрицу D0. Наша цель состоит в определении матрицы DN, представляющей кратчайшие пути между всеми вершинами рассматриваемого графа.

В алгоритме Флойда в качестве исходной выступает матрица D0. Вначале из этой матрицы вычисляется матрица D1. Затем по матрице D1 вычисляется матрицав D2 и т.д. Процесс повторяется до тех пор, пока по матрице DN-1 не будет вычислена матрица DN.

Рассмотрим основную идею, лежащую в основе алгоритма Флойда. Суть алгоритма Флойда заключается в проверке того, не окажется ли путь из вершины i в вершину j короче, если он будет проходить через некоторую промежуточную вершину m. Предположим, что нам известны:

кратчайший путь из вершины i в вершину m, в котором в качестве промежуточных допускается использование только первых (m - 1) вершин;

кратчайший путь из вершины m в вершину j, в котором в качестве промежуточных допускается использование только первых (m - 1) вершин;

кратчайший путь из вершины i в вершину j, в котором в качестве промежуточных допускается использование только первых (m - 1) вершин.

Поскольку по предположению исходный граф не может содержать контуров отрицательной длины, один из двух путей - путь, совпадающий с представленным в пункте 3, или путь, являющийся объединением путей из пунктов 1 и 2 - должен быть кратчайшим путем из вершины i в вершину j, в котором в качестве промежуточных допускается использование только первых m вершин.

i,jm =min{di,mm-1+ dm,jm-1; di,jm -1}

 

Из соотношения видно, что для вычисления элементов матрицы Dm необходимо располагать лишь элементами матрицы Dm-1. Более того, соответствующие вычисления могут быть проведены без обращения к исходному графу.

 




2020-03-19 194 Обсуждений (0)
Пример применения алгоритма Дейкстры 0.00 из 5.00 0 оценок









Обсуждение в статье: Пример применения алгоритма Дейкстры

Обсуждений еще не было, будьте первым... ↓↓↓

Отправить сообщение

Популярное:
Как вы ведете себя при стрессе?: Вы можете самостоятельно управлять стрессом! Каждый из нас имеет право и возможность уменьшить его воздействие на нас...
Как распознать напряжение: Говоря о мышечном напряжении, мы в первую очередь имеем в виду мускулы, прикрепленные к костям ...



©2015-2024 megaobuchalka.ru Все материалы представленные на сайте исключительно с целью ознакомления читателями и не преследуют коммерческих целей или нарушение авторских прав. (194)

Почему 1285321 студент выбрали МегаОбучалку...

Система поиска информации

Мобильная версия сайта

Удобная навигация

Нет шокирующей рекламы



(0.008 сек.)