Студопедия Главная Случайная страница Обратная связь

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

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





Дан ориентированный граф G=< V, E> с матрицей весов А(Ar­ray [1..N, 1..N] Of Integer).

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

Идея алгоритма. Обозначим через Dm[i, j] оценку кратчайшего пути из i в j с промежуточными вершинами из множества [1..т]. Тогда имеем:

D°[i, j]: =A[i, j] и

D(m+1)[i, j]= Min{Dm[i, j], Dm[i, m+1 ] +Dm[m+1, j].

Второе равенство требует пояснения. Пусть мы на­ходим кратчайший путь из i в j с промежуточными вершинами из множества [1..(т+1)]. Если этот путь не содержит вершину (m+1), то D(m+1)[i, j]=Dm[i, j]. Если же он содержит эту вершину, то его можно разделить на две части: от i до (m+1) и от (m+1) до j.

 

Procedure Dist; (*А, D - глобальные структуры данных. *} Var m, i, j: Integer;

Begin

For i: =1 To N Do

For j: =1 To N Do D[i, j]: =A[i, j];

For i: =1 To N Do D[i, i]: =0;

For m: =1 Tо N Do

For i: = 1 To N Do

For j: =1 To N Do D[i, j]: =Min {D[i, j], D[i, m]+D[m, j] };

End;

 

Пример. На рисунке 7 представлены графа и значения мат­риц типа D при работе процеду­ры.

Верхний индекс у D (см. рис.8) указывает номер итерации (значение m в процедуре Dist).

 

 

 

Рис.7

 

Рис. 8

 

Расстояния между парами вершин дает D. Для вывода са­мих кратчайших путей введем матрицу М того же типа, что и D. Элемент M[i, j] определяет предпоследнюю вершину крат­чайшего пути из i в j.

Процедура Dist претерпит небольшие изменения. В том слу­чае, когда D[i, j] больше D[i, m]+D[m, j], изменяется не только D[i, j], но и M[i, j]. M[i, j] присваивается значение М[m, j]. Для нашего примера изменения М отражены на рис.9.

 

Рис.9

 

Например, необходимо вывести кратчайший путь из 3-й вер­шины во 2-ю. Элемент М[3, 2] равен 1, поэтому смотрим на элемент М[3, 1]. Он равен четырем. Сравниваем М[3, 4] с 3-й. Есть совпадение, мы получили кратчайший путь: 3" 4" 1" 2.

Procedure All_Way (i, j: Integer); {*Вывод пути между вершинами i и j. *}

Begin

If M(i, j]=i Then

If i=j Write(i) Else Write (i, '-', j)

Else

Begin All_Way (i, M[i, j]); All_Way (M[i, j ], j);

End;

End;

 







Дата добавления: 2014-11-10; просмотров: 648. Нарушение авторских прав; Мы поможем в написании вашей работы!




Обзор компонентов Multisim Компоненты – это основа любой схемы, это все элементы, из которых она состоит. Multisim оперирует с двумя категориями...


Композиция из абстрактных геометрических фигур Данная композиция состоит из линий, штриховки, абстрактных геометрических форм...


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


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

Тема: Составление цепи питания Цель: расширить знания о биотических факторах среды. Оборудование:гербарные растения...

В эволюции растений и животных. Цель: выявить ароморфозы и идиоадаптации у растений Цель: выявить ароморфозы и идиоадаптации у растений. Оборудование: гербарные растения, чучела хордовых (рыб, земноводных, птиц, пресмыкающихся, млекопитающих), коллекции насекомых, влажные препараты паразитических червей, мох, хвощ, папоротник...

Типовые примеры и методы их решения. Пример 2.5.1. На вклад начисляются сложные проценты: а) ежегодно; б) ежеквартально; в) ежемесячно Пример 2.5.1. На вклад начисляются сложные проценты: а) ежегодно; б) ежеквартально; в) ежемесячно. Какова должна быть годовая номинальная процентная ставка...

ТЕРМОДИНАМИКА БИОЛОГИЧЕСКИХ СИСТЕМ. 1. Особенности термодинамического метода изучения биологических систем. Основные понятия термодинамики. Термодинамикой называется раздел физики...

Травматическая окклюзия и ее клинические признаки При пародонтите и парадонтозе резистентность тканей пародонта падает...

Подкожное введение сывороток по методу Безредки. С целью предупреждения развития анафилактического шока и других аллергических реак­ций при введении иммунных сывороток используют метод Безредки для определения реакции больного на введение сыворотки...

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