Аннотация: Рассматриваются вопросы достижимости для орграфов и способы нахождения матриц достижимости и контрдостижимости. Рассматривается матричный способ нахождения количества путей между любыми вершинами графа, а также нахождение множества вершин, входящих в путь между парой вершин. Цель лекции: Дать представление о достижимости и контрдостижимости и способах их нахождения
Достижимость и контрдостижимость
Задач, в которых используется понятие достижимости, довольно много. Вот одна из них. Граф может быть моделью какой-то организации, в которой люди представлены вершинами, а дуги интерпретируют каналы связи. При рассмотрении такой модели можно поставить вопрос, может ли информация от одного лица хi быть передана другому лицу хj, т. е. существует ли путь, идущий от вершины хi к вершине хj. Если такой путь существует, то говорят, что вершина хj достижима из вершины хi. Можно интересоваться достижимостью вершины хj из вершины хi только на таких путях, длины которых не превосходят заданной величины или длина которых меньше наибольшего числа вершин в графе и т. п. задачи.
Достижимость в графе описывается матрицей достижимости R=[rij], i, j=1, 2, … n, где n – число вершин графа, а каждый элемент определяется следующим образом:
rij=1, если вершина хj достижима из хi,
rij=0, в противном случае.
Множество вершин R(xi) графа G, достижимых из заданной вершины xi, состоит из таких элементов xj, для которых (i, j)-й элемент в матрице достижимостей равен 1. Очевидно, что все диагональные элементы в матрице R равны 1, поскольку каждая вершина достижима из себя самой путeм длины 0. Поскольку прямое отображение 1-го порядка Г+1(xi) является множеством таких вершин xj, которые достижимы из xi с использованием путей длины 1, то множество Г+(Г+1(xi)) = Г+2(xi) состоит из вершин, достижимых из xi с использованием путей длины 2. Аналогично Г+p(xi) является множеством вершин, которые достижимы из xi с помощью путей длины p.
Так как любая вершина графа, которая достижима из xi, должна быть достижима с использованием пути (или путей) длины 0 или 1, или 2, …, или p, то множество вершин, достижимых для вершины xi, можно представить в виде
.
Как видим, множество достижимых вершин R(xi) представляет собой прямое транзитивное замыкание вершины xi, т. е. R (xi) = T+(xi). Следовательно, для построения матрицы достижимости находим достижимые множества R (xi) для всех вершин . Полагая, rij=1, если
и rij=0 в противном случае.
Рис.
4.1.
Достижимость в графе: а –граф; б – матрица смежности; в – матрица достижимости; г- матрица контрдостижимости.
Для графа, приведенного на
рис.
4.1,а, множества достижимостей находятся следующим образом:
,
,
,
,
,
,
.
Матрица достижимости имеет вид, как показано на
рис.
4.1,в. Матрицу достижимости можно построить по матрице смежности (
рис.
4.1,б), формируя множества T+(xi) для каждой вершины xi
.
Матрица контрдостижимости Q = [ qij], i, j =1, 2, … n, где n – число вершин графа, определяется следующим образом:
qij=1, если из вершины xj
можно достичь вершину xi
,
qij=0, в противном случае.
Контрдостижимым множеством Q (xi) является множество таких вершин, что из любой вершины этого множества можно достичь вершину xi
. Аналогично построению достижимого мно-жества R (xi) можно записать выражение для Q (xi):
.
Таким образом, видно, что Q (xi) – это есть не что иное как обратное транзитивное замыкание вершины xi
, т. е. Q (xi) = Т—xi). Из определений очевидно, что столбец xi
матрицы Q (в котором qij=1, если , и qij=0 в противном случае) совпадает со строкой xi
матрицы R, т. е. Q = RT,где RT
– матрица, транспонированная к матрице достижимости R.
Матрица контрдостижимости показана на
рис.
4.1,г.
Следует отметить, что поскольку все элементы матриц R и Q равны 1 или 0, то каждую строку можно хранить в двоичной форме, экономя затраты памяти ЭВМ. Матрицы R и Q удобны для обработки на ЭВМ, так как с вычислительной точки зрения основными операциями являются быстродействующие логические операции.
Привет, сегодня поговорим про матрица достижимости, обещаю рассказать все что знаю. Для того чтобы лучше понимать что такое
матрица достижимости , настоятельно рекомендую прочитать все из категории Дискретная математика. Теория множеств . Теория графов . Комбинаторика..
матрица достижимости простого ориентированого графа — бинарная матрица замыкания по транзитивности отношения
(оно задается матрицей смежности графа). Таким образом, в матрице достижимости хранится информация о существовании путей между вершинами орграфа.
В теории графов , достижимость относится к способности , чтобы получить от одной вершины к другой в пределах графика. Вершина может достичь вершины
(а также
доступен из
), если существует последовательность смежных вершин (т.е. путь ), начинающаяся с
и заканчивается
.
В неориентированном графе достижимость между всеми парами вершин может быть определена путем идентификации связанных компонентов графа. Любая пара вершин в таком графе может достигать друг друга тогда и только тогда, когда они принадлежат одной компоненте связности; следовательно, в таком графе достижимость симметрична ( достигает
если только
достигает
). Связные компоненты неориентированного графа могут быть идентифицированы за линейное время. Остальная часть статьи посвящена более сложной проблеме определения попарной достижимости в ориентированном графе (который, кстати, не обязательно должен быть симметричным).
Матица достижимости неориентированного графа.
Утверждение. ЕслиА– матрица смежности графа, то элемент
матрицыАправен числу маршрутов длинып, соединяющих вершиныvi иvjграфаG.
Доказательство.Методом математической индукции по числуп.
База индукции.Прип= 1 утверждение верно, так как всякое ребро графаG– это маршрут длины 1.
Индуктивное предположение.Пусть утверждение справедливо для всехnk.
Индуктивный переход.Рассмотрим матрицуАk+1. В ней.
В силу индуктивного предположения произведение есть число маршрутов длиныk+ 1, соединяющих вершинуvi с вершинойvjс предпоследней вершиной всех таких маршрутовvm. Значит, сумма
действительно равна числу маршрутов длинk+ 1, соединяющих вершинуvi с вершинойvj.
Следствие.Пусть– связный граф срвершинами. Тогда любые две вершины графа
можно соединить простой цепью. Но в простой цепи не может быть более (р1) ребер. Следовательно, все элементы матрицы
отличны от нуля. Ясно, что верно и обратное утверждение.
В некоторых случаях при вычислениях степеней матрицы Аи матрицыСважно знать не число соответствующих маршрутов, а только есть ли в графе эти маршруты или нет . Об этом говорит сайт https://intellect.icu . Тогда при вычислении элементов матрицА2,А3, … ,Ар-1вместо обычного сложения используют операцию, введенную нами при рассмотрении матриц конечных бинарных отношений. В результате матрицыА,А2,А3, …,Ap—1,Cсостоят только из нулей и единиц.
Полученная таким образом матрица Сназываетсяматрицей достижимостиграфаG. ГрафGсвязен тогда и только тогда, когда каждый элемент матрицы достижимости равен 1 (р3).
Матрица достижимости ориентированного графа.
Случай орграфа ничем не отличается от случая неориентированного графа. Если G– орграф ср вершинами иА– его матрица смежности, то элементматрицыАправен числу ориентированных маршрутов длинып, соединяющих вершинуvi с вершинойvj.
+Граф G сильно связен тогда и только тогда, когда каждый элемент его матрицы достижимостиравен 1.
Способы построения матрицы достижимости
Перемножение матриц
Пусть дан простой граф , матрица смежности которого есть
, где
. Матрица смежности дает информацию о всехпутях длины 1 (то есть, ребрах) в ографе. Для поиска путей длины 2 можно найти композицию отношения
с самим собой:
.
По определению, матрица композиции отношений есть
, где
— конъюнкция, а
— дизъюнкция.
После нахождения матриц композиций
для всех
,
будет получена информация о всех путях длины от
до
. Таким образом, матрица
есть искомая матрица достижимости.
Случай нескольких путей
Если булевы операции дизъюнкции и конъюнкции заменить обычными алгебраическими операциями
сложения и умножения соответственно, нахождение матрицы достижимости
сведется к обычному пошаговому перемножению матриц с последующим сложением результатов каждого шага. Тогда получившаяся матрица
будет состоять не только из 0 и 1 и будет характеризовать не только наличие путей между вершинами, но уже и количество таких путей. В таком случае можно разрешить наличие кратных ребер в графе.
Пример
Граф
Рассмотрим простой связный ориентированный граф . Он имеет матрицу смежности
вида:
Найдем булевы степени этой матрицы ,
,
:
,
,
.
Получим матрицу достижимости
Таким образом, из вершины можно добраться в любую другую.
При использовании же алгебраических операций получится матрица
Она показывает количество путей длины от 1 до 4 между вершинами орграфа.
Алгоритм Уоршелла
Алгоритм Уоршелла
Существует другой алгоритм, позволяющий найти матрицу достижимости в точности за шагов — алгоритм Уоршелла.
Связанные понятия
Матрица сильной связности
Матрица сильной связности простого орграфа — бинарная матрица, содержащая информацию обо всех сильно связанных вершинах в орграфе. Матрица сильной связности симметрична. У сильно связного графа такая матрица заполнена единицами.
Построение матрицы сильной связности
Матрица сильной связности может быть построена из матрицы достижимости. Пусть — матрица достижимости орграфа
. Тогда матрица сильной связности
состоит из элементов
.
Пример
Рассмотрим тот же граф, что и ранее.
Его матрица достижимости:
Из нее получаем матрицу сильной связности:
Вершины 3 и 4 сильно связаны друг с другом и сами с собой.
Матрица связности графа
Для связного графа существует понятие матрицы связности, сходное с матрицей достижимости.
Программа 1. Вычисление матрицы достижимости по заданной матрице смежностей с помощью алгоритма Уоршалла.
#include <iostream.h> #define MaxNodes 4 class Warshall { private: unsigned Adj[MaxNodes][MaxNodes]; //Матрица смежностей. unsigned Path[MaxNodes][MaxNodes]; //Матрица достижимости. public: void Vvod(); void TransClose(); void Vyvod(); }; void Warshall::Vvod() { //Ввод матрицы смежностей заданного графа. cout <<"Вводите элементы матрицы смежностей по строкам:n"; for (int i=0;i<MaxNodes;i++) for (int j=0;j<MaxNodes;j++) { cout <<"Введите Adj["<< (i+1) << "]["<< (j+1) << "]: "; cin >> Adj[i][j]; } } void Warshall::TransClose() //Вычисление матрицы достижимости. { //Инициализация матрицы Path матрицей смежностей Adj. for (int i=0;i<MaxNodes;i++) for (int j=0;j<MaxNodes;j++) Path[i][j] = Adj[i][j]; //Нахождение следующих значений матрицы Path. for (int k=0;k<MaxNodes;k++) for (i=0;i<MaxNodes;i++) if (Path[i][k]==1) for (int j=0;j<MaxNodes;j++) Path[i][j] = (Path[i][j] || Path[k][j]); } void Warshall::Vyvod() //Вывод матрицы достижимости. { cout << "Матрица достижимости:n"; for (int i=0;i<MaxNodes;i++) { for (int j=0;j<MaxNodes;j++) cout << Path[i][j] << " "; cout << endl; } } void main() { Warshall A; A.Vvod(); A.TransClose(); A.Vyvod(); }
Связанные проблемы
Связанная с этим проблема — решить запросы о достижимости с некоторым числом. вершинных отказов. Например: «Может вершина
все еще дойти до вершины
хотя вершины
потерпели неудачу и больше не могут быть использованы? »Подобная проблема может относиться к сбоям ребер, а не к сбоям вершин, или их сочетанию. Методика поиска в ширину работает так же хорошо с такими запросами, но создание эффективного оракула более важно сложно.
Другая проблема, связанная с запросами о достижимости, заключается в быстром пересчете изменений отношений достижимости при изменении какой-либо части графа. Например, это актуальная проблема для сборки мусора, которая должна сбалансировать восстановление памяти (чтобы ее можно было перераспределить) с проблемами производительности работающего приложения.
Вау!! 😲 Ты еще не читал? Это зря!
- Гаммоид
- st -соединение
Напиши свое отношение про матрица достижимости. Это меня вдохновит писать для тебя всё больше и больше интересного. Спасибо Надеюсь, что теперь ты понял что такое матрица достижимости
и для чего все это нужно, а если не понял, или есть замечания,
то нестесняся пиши или спрашивай в комментариях, с удовольствием отвечу. Для того чтобы глубже понять настоятельно рекомендую изучить всю информацию из категории
Дискретная математика. Теория множеств . Теория графов . Комбинаторика.
Достижимость и контрдостижимость
Задач,
в которых используется понятие
достижимости,
довольно много. Вот одна из них. Граф
может быть моделью какой-то организации,
в которой люди представлены вершинами,
а дуги интерпретируют каналы связи. При
рассмотрении такой модели можно поставить
вопрос, может ли информация от одного
лица хi
быть передана другому лицу хj
, т. е. существует ли путь, идущий от
вершины хi
к вершине хj
. Если такой путь существует, то говорят,
что вершина хj
достижима из вершины хi
. Можно интересоваться достижимостью
вершины хj
из вершины хi
только на таких путях, длины которых не
превосходят заданной величины или длина
которых меньше наибольшего числа вершин
в графе и т. п. задачи.
Достижимость
в графе описывается матрицей достижимости
R=[rij],
i, j=1, 2, … n, где n – число вершин графа, а
каждый элемент определяется следующим
образом:
rij=1,
если вершина хj
достижима из хi
,
rij=0,
в противном случае.
Множество
вершин R(xi)графа
G, достижимых из заданной вершины xi
, состоит из таких элементов xi
, для которых (i, j)-й элемент в матрице
достижимостей
равен 1. Очевидно, что все диагональные
элементы в матрице R равны 1, поскольку
каждая вершина достижима из себя самой
путeм длины 0. Поскольку прямое отображение
1-го порядка Г+1(xi)
является множеством таких вершин xj
, которые достижимы из xi
с использованием путей длины 1, то
множество Г+(Г+1(xi))
= Г+2(xi)
состоит из вершин, достижимых из xi
с использованием путей длины 2. Аналогично
Г+p(xi)является
множеством вершин, которые достижимы
из xi
с помощью путей длины p.
Так
как любая вершина графа, которая достижима
из xi
, должна быть достижима с использованием
пути (или путей) длины 0 или 1, или 2, …,
или p, то множество вершин, достижимых
для вершины xi
, можно представить в виде
R
(xi)
= { xi
}
Г+1(xi)
Г+2(xi)
…
Г+p(xi).
Как
видим, множество достижимых вершин
R(xi)представляет
собой прямое транзитивное замыкание
вершины xi
, т. е. R (xi)
= T+(xi).
Следовательно, для построения матрицы
достижимости находим достижимые
множества R (xi)для
всех вершин xiX.
Полагая, rij=1,
если xj
R
(xi)и
rij=0
в противном случае.
Рис.
4.1.
Достижимость в графе: а –граф; б –
матрица смежности; в – матрица
достижимости; г- матрица контрдостижимости.
Для
графа, приведенного на рис.
4.1,а,
множества достижимостей находятся
следующим образом:
R
(х1)
= { х1
}
{
х2,
х5
}
{
х2,
х4,
х5
}
{
х2,
х4,
х5
} = = { х1,
х2,
х4,
х5
},
R
(х2)
= { х2
}
{
х2,
х4
}
{
х2,
х4,
х5
}
{
х2,
х4,
х5
} = = { х2,
х4,
х5
},
R
(х3)
= { х3
}
{
х4
}
{
х5
}
{
х5
} = { х3,
х4,
х5
},
R
(х4)
= { х4
}
{
х5
}
{
х5
} = { х4,
х5
},
R
(х5)
= { х5
}
{
х5
} = { х5
},
R(х6)=
{х6
}{
х3,
х7
}{
х4,
х6
}{
х3,
х5,
х7
}{
х4,
х5,
х6
} = { х3,
х4,
х5,
х6,
х7},
R
(х7)
= { х7
}
{
х4,
х6
}
{
х3,
х5,
х7
}
{
х4,
х5,
х6
} = = { х3,
х4,
х5,
х6,
х7
}.
Матрица
достижимости
имеет вид, как показано на рис.
4.1,в.
Матрицу
достижимости
можно построить по матрице смежности
(рис.
4.1,б),
формируя множества T+xi)для
каждой вершины xi
.
Матрица
контрдостижимости
Q = [ qij],
i, j =1, 2, … n, где n – число вершин графа,
определяется следующим образом:
qij=1,
если из вершины xj
можно достичь вершину xi
,
qij=0,
в противном случае.
Контрдостижимым
множеством Q(xi)
является множество таких вершин, что
из любой вершины этого множества можно
достичь вершину xi.
Аналогично построению достижимого
множества R (xi)можно
записать выражение для Q (xi):
Q
(xi)
= { xi
}
Г-1xi)
Г-2xi)
…
Г-pxi).
Таким
образом, видно, что Q (xi)
– это есть не что иное как обратное
транзитивное замыкание вершины xi
, т. е. Q (xi)
= Т—xi).
Из определений очевидно, что столбец
xi
матрицы Q (в котором qij=1,
если xj
Q
(xi),
и qij=0
в противном случае) совпадает со строкой
xi
матрицы R, т. е. Q = RT,
где RT
– матрица, транспонированная к матрице
достижимости
R.
Матрица
контрдостижимости
показана на рис.
4.1,г.
Следует
отметить, что поскольку все элементы
матриц R и Q равны 1 или 0, то каждую строку
можно хранить в двоичной форме, экономя
затраты памяти ЭВМ. Матрицы R и Q удобны
для обработки на ЭВМ, так как с
вычислительной точки зрения основными
операциями являются быстродействующие
логические операции.
Соседние файлы в предмете [НЕСОРТИРОВАННОЕ]
- #
- #
- #
- #
- #
- #
- #
- #
- #
- #
- #
Тема: Уравнения в идемпотентных полукольцах. Гомоморфизм графов. Алгоритмы обхода вершин графа.. Читаем, комментируем, решаем ДЗ.
Идемпотентные полукольца
Идемпотентным называется полукольцо, ,
в котором операция сложения идемпотентна: .
Примером таких полуколец являются:
В указанных полукольцах для каждого элемента можно ввести операцию итерации:
— бесконечная сумма степеней
элементов. Под степенью элемента понимается умножение его на себя
раз, а нулевая
степень равна единице полукольца по определению: .
Для приведённых выше полуколец итерация для любых элементов находится очень просто:
:
: для любого
Идемпотентные полукольца интересны тем, что в них можно решать уравнения вида:
Интересно, что такие необычные для арифметики уравнения как или
имеют здесь единственные решения:
Нахождение матрицы достижимости
Важной задачей в теории графов является нахождение матрицы достижимости по матрице
смежности. Можно доказать, что матрица достижимости может быть получена как итерация
матрицы смежности:
Таким образом, для получения матрицы необходимо решить
систем уравнений следующего
вида для :
где — элементы матрицы смежности, а
— элементы единичной
матрицы. Решением каждой из систем будет -й столбец матрицы
.
|
Рассмотрим пример. На рисунке 1 показан ориентированный граф из шести
вершин, матрица смежности которого равна:
- 1-й столбец
- 2-й столбец
- 3-6 столбцы
Полученная матрица достижимости примет вид:
Нахождение кратчайших путей
Теория графов широко применяется при решении транспортных задач — нахождения кратчайших
маршрутов в графах дорог, сетей и т.п. Для этого используются размеченные графы:
, где
— весовая функция над
некоторым полукольцом . Т.е. каждому ребру (или дуге)
сопоставляется число, символизирующее длину пути, сложнсть задачи или любую другую
стоимость перемещения между вершинами.
Рассмотрим граф, размеченный над полукольцом (см. рисунок 2).
|
Для такого графа можно записать матрицу метог дуг (эта матрица аналогична
матрице смежностей), где
В нашем случае матрица меток дуг равна:
Матрица стоимостей находится аналогично, с помощью решения
систем уравнений. Важно
отметить, что в данном случае вся работа ведётся в полукольце , в котором
нулём полукольца является , а единицей — 0!
- 1-й столбец
- 2-й столбец
- 3-6 столбцы
Полученная матрица стоимостей будет иметь вид:
Гомоморфизм и автоморфизм графов
Примеры гомоморфизма и не гомоморфизма представлены на рисунке 3.
|
Аналогичным образом гомоморфизм определяется для ориентированных графов. Рассмотрим
соответвтующий пример: для заданного графа (см. рисунок 4) необходимо
найти все друхвершинные гомоморфные образы.
|
Изоморфизм графа на себя (перестановка вершин) называется автоморфизмом.
Для анализа возможных существующих автоморфизмов в неориентированных графах удобно
использовать дополнения к графам: граф с тем же набором вершин и набором дуг, не
принадлежащих исходному графу. На рисунке 5 показан исходный граф и
его дополнение.
|
Можно увидеть, что любая перестановка из множества дополнении к графу оставит граф
неизменным:
Такие циклические перестановки можно записать в сокращённом виде:
Алгоритмы обхода графов. Поиск в глубину, поиск в ширину
Часто возникает задача обхода вершин и рёбер графа, т.е. посещение всех вершин или
рёбер, причём только по одному разу. Такой обход может использоваться, например, в поиске
информациии на графе. Существуют два широко известных алгоритма обхода вершин графа: поиск
в глубину и поиск в ширину. В обоих из них поиск ведётся от какой-то вершины, избранной в
качестве начальной.
Поиск в глубину использует в своей работе рекурсию (или стэк в явном виде). Основная идея
алгоритма состоит в «погружении» в граф от начальной вершины на максимально возможную
глубину, а затем постепенный возврат из рекурсивных вызовов.
С помощью рекурсии алгоритм поиска в глубину можно представить следующим образом:
bool visited[N] = {false, ... }; // массив флагов посещённых вершин edge edges[M]; // массив рёбер // рекурсивная процедура поиска void deep_search(vertex_t v) { visited[v] = true; // отметить вершину как посещённую ... // сделать с вершиной то, ради чего обход затевался for(size_t i = 0; i < M; i++) { edge e = edges[i]; if(e.from == v && !visited[e.to]) { deep_search(e.to); } } }
Если стэк использовать явным образом, можно избавиться от рекурсивного вызова:
bool visited[N] = {false, ... }; // массив флагов посещённых вершин edge edges[M]; // массив рёбер stack<vertex_t> s; // стэк // нерекурсивная процедура поиска void deep_search(vertex_t v0) { s.push(v0); while(!s.empty()) { vertex_t v = s.pop(); if(visited[v]) continue; // пропустить посещённую вершину visited[v] = true; // отметить вершину как посещённую ... // сделать с вершиной что-то for(size_t i = 0; i < M; i++) { edge e = edges[i]; if(e.from == v && !visited[e.to]) { s.push(e.to); } } } }
В обоих случаях поиск запускается вызовом процедуры с параметром начальной вершины.
Рассмотрим пример поиска в глубину на неориентированном графе, изображённый не рисунке
6. Остовный подграф, получившийся при обходе вершин обозначен
пунктиром. Очевидно, что этот подграф является деревом с корнем в начальной вершине, а его
вид будет зависеть от порядка обхода вершин во внутреннем цикле рекурсивной процедуры.
|
Порядок следования вершин и состояние стэка на каждом шаге:
Аналогично производится поиск в глубину на ориентированном графе (см. рисунок
7).
|
С помощью алгоритма поиска в глубину можно классифицировать дуги ориентированного графа
следующим образом:
- остовные дуги
- получаются непосредственно при поиске в глубину, образуют дерево (или
в общем случае лес), на рисунке обозначены пунктиром; - прямые дуги
- соединяют предка и потомка в остовном пути, на рисунке обозначены
буквой F; - обратные дуги
- соединяют потомка и предка в остовном пути, на рисунке обозначены
буквой B, интересно то, что каждая из таких дуг задаёт элементарный контур в графе; - перекрёстные дуги
- все остальные дуги, на рисунке обозначены буквой C.
Вторым широко распространённым алгоритмом является поиск в глубину. Это алгоритм
использует очередь для хранения списка обрабатываемых вершин. В результате работы
алгоритмя также получается остовное дерево, которое в общем случае отличается от дерева
поика в глубину. Можно предложить следующий алгоритм поиска в ширину:
bool visited[N] = {false, ... }; // массив флагов посещённых вершин edge edges[M]; // массив рёбер queue<vertex_t> q; // очередь // процедура поиска void wide_search(vertex_t v0) { q.push(v0); while(!q.empty()) { vertex_t v = q.pop(); if(visited[v]) continue; // пропустить посещённую вершину visited[v] = true; // отметить вершину как посещённую ... // сделать с вершиной что-то for(size_t i = 0; i < M; i++) { edge e = edges[i]; if(e.from == v && !visited[e.to]) q.push(e.to); } } }
|
Рассмотрим пример поиска в ширину на неориентированном графе, изображённый не рисунке
8. Остовный подграф, получившийся при обходе вершин обозначен
пунктиром. Порядок следования вершин и состояние очереди на каждом шаге представлены в табице:
По матрице смежности нужно построить матрицу достижимости. Использую Алгоритм Флойда — Уоршелла:
for (int k = 0; k < n; k++)
for (int i = 0; i < n; i++)
for (int j = 0; j < n; j++)
W[i][j] = (W[i][j] || (W[i][k] && W[k][j]));
На графе
0 1 0 0 0
0 0 0 1 0
0 1 0 0 0
0 0 1 0 0
1 0 1 1 0
Данный алгоритм выдает:
0 1 1 1 0
0 1 1 1 0
0 1 1 1 0
0 1 1 1 0
1 1 1 1 0
Но на сайте у них получилась немного другая матрица. T(D)
Где ошибка?
pegoopik
3,43014 серебряных знаков51 бронзовый знак
задан 3 фев 2016 в 20:33
3
Никакой ошибки нет.
Посмотрите внимательно на граф:
Из узлов 2 3 4 можно добраться «из себя в себя» по некоторому пути.
А из узлов 1 и 5 «в себя» не доберёшься.
Поэтому такая матрица и получается:
0 1 1 1 0
0 1 1 1 0
0 1 1 1 0
0 1 1 1 0
1 1 1 1 0
Если вам для задачи этой информации не требуется, то после работы алгоритма можно пробежаться по диагональным элементам и проставить единички.
ответ дан 18 фев 2016 в 9:44
pegoopikpegoopik
3,43014 серебряных знаков51 бронзовый знак