Студопедия — Алгоритм Дейкстры.
Студопедия Главная Случайная страница Обратная связь

Разделы: Автомобили Астрономия Биология География Дом и сад Другие языки Другое Информатика История Культура Литература Логика Математика Медицина Металлургия Механика Образование Охрана труда Педагогика Политика Право Психология Религия Риторика Социология Спорт Строительство Технология Туризм Физика Философия Финансы Химия Черчение Экология Экономика Электроника

Алгоритм Дейкстры.






Задание.

Найти кратчайшее расстояние между вершинами S (7) и T (8) c помощью алгоритма Дейкстры.

 

 

Начальная и конечная вершины в программе выделяются оранжевым цветом.

 

Алгоритм Дейкстры.

Алгоритм Дейкстры находит кратчайшее расстояние от одной вершины графа до всех остальных. Алгоритм работает только для графов без ребер отрицательного веса.

 

1. Присвоение начальных значений.

Приписываем вершине S постоянную метку d(S) = 0, а всем остальным вершинам x ∈ V, отличным от S, временные метки d(x) = ∞.

Положим y = S, где y — последняя из вершин, получивших постоянную метку.

 

2. Обновление пометок.

Для всех вершин x, смежных с y и не имеющих постоянной метки, пересчитаем величины d(x) по следующей формуле:

d(x) = min { d(x), d(y) + a(y, x) }

Если d(x) = ∞ для всех непомеченных вершин x, закончить процедуру алгоритма: в исходном графе отсутствуют пути из S в помеченные вершины.

В противном случае переходим к шагу 3.

 

3. Выбор вершины с наименьшей меткой.

Выбрать ту из вершин x, которая имеет наименьшую временную метку, т.е. ту, для которой величина d(x) является наименьшей.

 

4. Превращение метки в постоянную.

Положим y = x — вершина графа с наименьшей временной меткой, которой присваивается постоянная метка.

 

5. Проверка результата.

Если y = T, закончить процедуру. Кратчайший путь из вершины S в вершину T найден. Это единственный путь из S в T, составленный из помеченных дуг.

Если y≠x, перейти к шагу 2.







Дата добавления: 2015-09-04; просмотров: 1189. Нарушение авторских прав; Мы поможем в написании вашей работы!



Важнейшие способы обработки и анализа рядов динамики Не во всех случаях эмпирические данные рядов динамики позволяют определить тенденцию изменения явления во времени...

ТЕОРЕТИЧЕСКАЯ МЕХАНИКА Статика является частью теоретической механики, изучающей условия, при ко­торых тело находится под действием заданной системы сил...

Теория усилителей. Схема Основная масса современных аналоговых и аналого-цифровых электронных устройств выполняется на специализированных микросхемах...

Логические цифровые микросхемы Более сложные элементы цифровой схемотехники (триггеры, мультиплексоры, декодеры и т.д.) не имеют...

Реформы П.А.Столыпина Сегодня уже никто не сомневается в том, что экономическая политика П...

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

Особенности массовой коммуникации Развитие средств связи и информации привело к возникновению явления массовой коммуникации...

Функциональные обязанности медсестры отделения реанимации · Медсестра отделения реанимации обязана осуществлять лечебно-профилактический и гигиенический уход за пациентами...

Определение трудоемкости работ и затрат машинного времени На основании ведомости объемов работ по объекту и норм времени ГЭСН составляется ведомость подсчёта трудоёмкости, затрат машинного времени, потребности в конструкциях, изделиях и материалах (табл...

Гидравлический расчёт трубопроводов Пример 3.4. Вентиляционная труба d=0,1м (100 мм) имеет длину l=100 м. Определить давление, которое должен развивать вентилятор, если расход воздуха, подаваемый по трубе, . Давление на выходе . Местных сопротивлений по пути не имеется. Температура...

Studopedia.info - Студопедия - 2014-2024 год . (0.011 сек.) русская версия | украинская версия