Вам бонус- начислено 1 монета за дневную активность. Сейчас у вас 1 монета

Матрица достижимости кратко

Лекция



Привет, сегодня поговорим про матрица достижимости, обещаю рассказать все что знаю. Для того чтобы лучше понимать что такое матрица достижимости , настоятельно рекомендую прочитать все из категории Дискретная математика. Теория множеств . Теория графов . Комбинаторика..

матрица достижимости простого ориентированого графа Матрица достижимости — бинарная матрица замыкания по транзитивности отношения Матрица достижимости (оно задается матрицей смежности графа). Таким образом, в матрице достижимости хранится информация о существовании путей между вершинами орграфа.

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

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

Матица достижимости неориентированного графа.

Утверждение. ЕслиА– матрица смежности графаМатрица достижимости, то элементМатрица достижимостиматрицыАправен числу маршрутов длинып, соединяющих вершины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 и будет характеризовать не только наличие путей между вершинами, но уже и количество таких путей. В таком случае можно разрешить наличие кратных ребер в графе.

Пример

Матрица достижимости
Граф Матрица достижимости

Рассмотрим простой связный ориентированный граф Матрица достижимости. Он имеет матрицу смежности Матрица достижимости вида:


\mathbf E = 
\begin{pmatrix}
  0&1&1&0 \\
  0&0&0&0 \\
  0&1&0&1 \\
  0&0&1&0
\end{pmatrix}

Найдем булевы степени этой матрицы Матрица достижимости, Матрица достижимости, Матрица достижимости:


\mathbf{E^2} = 
\begin{pmatrix}
  0&1&0&1 \\
  0&0&0&0 \\
  0&0&1&0 \\
  0&1&0&1
\end{pmatrix}
, 
\mathbf{E^3} = 
\begin{pmatrix}
  0&0&1&0 \\
  0&0&0&0 \\
  0&1&0&1 \\
  0&0&1&0
\end{pmatrix}
, 
\mathbf{E^4} = 
\begin{pmatrix}
  0&1&0&1 \\
  0&0&0&0 \\
  0&0&1&0 \\
  0&1&0&1
\end{pmatrix}
.

Получим матрицу достижимости

Матрица достижимости

Таким образом, из вершины Матрица достижимости можно добраться в любую другую.

При использовании же алгебраических операций получится матрица

Матрица достижимости

Она показывает количество путей длины от 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 -соединение

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

Из статьи мы узнали кратко, но содержательно про матрица достижимости
создано: 2014-11-02
обновлено: 2024-11-14
1433



Рейтиг 10 of 10. count vote: 2
Вы довольны ?:


Поделиться:

Найди готовое или заработай

С нашими удобными сервисами без комиссии*

Как это работает? | Узнать цену?

Найти исполнителя
$0 / весь год.
  • У вас есть задание, но нет времени его делать
  • Вы хотите найти профессионала для выплнения задания
  • Возможно примерение функции гаранта на сделку
  • Приорететная поддержка
  • идеально подходит для студентов, у которых нет времени для решения заданий
Готовое решение
$0 / весь год.
  • Вы можите продать(исполнителем) или купить(заказчиком) готовое решение
  • Вам предоставят готовое решение
  • Будет предоставлено в минимальные сроки т.к. задание уже готовое
  • Вы получите базовую гарантию 8 дней
  • Вы можете заработать на материалах
  • подходит как для студентов так и для преподавателей
Я исполнитель
$0 / весь год.
  • Вы профессионал своего дела
  • У вас есть опыт и желание зарабатывать
  • Вы хотите помочь в решении задач или написании работ
  • Возможно примерение функции гаранта на сделку
  • подходит для опытных студентов так и для преподавателей

Комментарии


Оставить комментарий
Если у вас есть какое-либо предложение, идея, благодарность или комментарий, не стесняйтесь писать. Мы очень ценим отзывы и рады услышать ваше мнение.
To reply

Дискретная математика. Теория множеств . Теория графов . Комбинаторика.

Термины: Дискретная математика. Теория множеств . Теория графов . Комбинаторика.