Транзитивный остов
Версия от 23:21, 12 апреля 2012; Katyatitkova (обсуждение | вклад)
Определение: |
Транзитивным остовом (transitive reduction) отношения на множестве называется минимальное отношение на такое, что транзитивное замыкание равно транзитивному замыканию . |
Алгоритм для антисимметричных отношений
Для удобства представим отношение в виде графа:
. Его транзитивным остовом будет граф .Введём несколько обозначений:
- — в графе есть ребро из вершины в ;
- — в графе есть путь (возможно, рёберно пустой) из вершины в (то есть вершина достижима из );
- — в графе есть рёберно непустой путь из вершины в .
Также введём определение транзитивного замыкания в терминах теории графов:
Определение: |
Транзитивным замыканием графа | называется граф , где .
Так как отношение антисимметрично, то граф ацикличен, то есть в нём выполняется следующее: .
Докажем теорему, из которой следует алгоритм.
Теорема: |
Пусть . Тогда |
Доказательство: |
Доказательство, что содержится в множестве рёбер, заданных условием теоремы:Пусть уже построен. Пусть . Тогда (так как иначе удаление ребра из приведёт к образованию меньшего графа с тем же транзитивным замыканием, что нарушает условие минимальности транзитивного остова). Поэтому по определению транзитивного остова . Пусть — вершина, для которой выполняется . Докажем, что , от противного. Пусть . ацикличен, поэтому . Поскольку , верно . Поскольку ацикличен, путь из в не может содержать ребра . Аналогично путь из в не может содержать . Поэтому в существует путь из в , не содержащий в себе ребро . Поэтому удаление из не изменит транзитивное замыкание, что противоречит условию минимальности . Поэтому . Поскольку , существует такая вершина , что , что приводит к выводу, что .Доказательство, что множество вершин содержится в Предположим, что : и , но . Докажем противоречие. Поскольку ацикличен, и поэтому . Поскольку , существует вершина такая, что и . Поэтому . Поскольку ацикличен, существует вершина , для которой выполняется , что противоречит нашему предположению. |
Псевдокод
= foreach in foreach in foreach in if and and .delete(pair( , ))