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

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

Каркас минимального веса. Метод Р. Прима






Дано. Связный неориентированный граф G=< V, E>. Ребра имеют вес. Граф описывается матрицей смежности А (Array [1..N, 1..N] Of Integer). Элемент матрицы, не равный нулю, определяет вес ребра.

Результат. Каркас с минимальным суммарным весом Q=(V, T), где T E.

Отличие от метода Краскала заключается в том, что на каждом шаге строится дерево, а не ациклический граф, т. е. добав­ляется ребро с минимальным весом, одна вершина которого принадлежит каркасу, а другая нет. Такой принцип «добавле­ния» исключает возможность появления циклов. Для реализа­ции метода необходимы две величины множественного типа SM и SP (Set Of 1..N). Первона­чально значением SM являют­ся все вершины графа, a SP пу­сто. Если ребро < i, j> включается в 7\ то один из но­меров вершин i и / исключает­ся из SM и добавляется в SP (кроме первого шага, на кото­ром оба номера переносятся в SP).

 

 

рис.2

Пример. На рисунке 2 приведен граф, для которого последовательно строится каркас. Процесс построения (изменения SM, SP) показан на следующих рисунках.

 

                       
   
SM-[1, 2, 5..7] SP-[3, 4]
     
SM-[1, 5..7] SP-[2.-4]
 
 
     
 
 
   
 

 

 


рис.3

 
 

Логика построения каркаса.

Procedure Tree; { *А - глобальная структура данных. *}

Var SM, SP: Set Of 1..N;

min, i, j, 1, k, t: Integer;

Begin

min: =maxint; SM: =[1..N];

SP: =[];

{*Включаем первоеребро в каркас. *}

For i: =l То N-l Do

For j: =i+l To N Do

If (A[i, j]< min) And (A[i, j]< > 0) Then

Begin

min: =A[i, j]; 1: =i; t: =j;

End;

SP: = [l, t]; SM: =SM-[l, t] < выводим илизапоминаем ребро < l, t»;

{^Основной цикл. *} While SM< > [] Do Begin min: =maxint; l: =0; t: =0; For i: =l To N Do If Not (i In SP) Then For j: =1 To N Do If (j In SP) And (A[i, j]< min) And (A[i, j]< > 0) Then

Begin min: =A[j, k]; 1: =i; t: =j; End; SP: =SP+[1]; SM: =SM-[1]; < выводим или запоминаем ребро < lft»;

End;

End;

 







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



Кардиналистский и ординалистский подходы Кардиналистский (количественный подход) к анализу полезности основан на представлении о возможности измерения различных благ в условных единицах полезности...

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

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

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

Закон Гука при растяжении и сжатии   Напряжения и деформации при растяжении и сжатии связаны между собой зависимостью, которая называется законом Гука, по имени установившего этот закон английского физика Роберта Гука в 1678 году...

Характерные черты официально-делового стиля Наиболее характерными чертами официально-делового стиля являются: • лаконичность...

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

Этические проблемы проведения экспериментов на человеке и животных В настоящее время четко определены новые подходы и требования к биомедицинским исследованиям...

Классификация потерь населения в очагах поражения в военное время Ядерное, химическое и бактериологическое (биологическое) оружие является оружием массового поражения...

Факторы, влияющие на степень электролитической диссоциации Степень диссоциации зависит от природы электролита и растворителя, концентрации раствора, температуры, присутствия одноименного иона и других факторов...

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