Транзитивный остов — различия между версиями
| Alexandra (обсуждение | вклад)  (→Псевдокод) | Alexandra (обсуждение | вклад)   (→Псевдокод) | ||
| Строка 42: | Строка 42: | ||
| === Псевдокод === | === Псевдокод === | ||
|    <tex> R^- </tex> = <tex> R </tex> |    <tex> R^- </tex> = <tex> R </tex> | ||
| − |    foreach <tex> a </tex> in <tex> X </tex> | + |    '''foreach''' <tex> a </tex> in <tex> X </tex> | 
| − |      foreach <tex> b </tex> in <tex> X </tex> | + |      '''foreach''' <tex> b </tex> in <tex> X </tex> | 
| − |        foreach <tex> c </tex> in <tex> X </tex> | + |        '''foreach''' <tex> c </tex> in <tex> X </tex> | 
| − |          if <tex> aRb </tex> and <tex> bRc </tex> and <tex> aRc </tex> | + |          '''if''' <tex> aRb </tex> '''and''' <tex> bRc </tex> '''and''' <tex> aRc </tex> | 
|            <tex> R^- </tex>.delete(pair<tex>\langle a </tex>, <tex> c \rangle</tex>) |            <tex> R^- </tex>.delete(pair<tex>\langle a </tex>, <tex> c \rangle</tex>) | ||
Версия 20:20, 8 января 2017
| Определение: | 
| Транзитивным остовом (англ. transitive reduction) отношения на множестве называется минимальное отношение на такое, что транзитивное замыкание равно транзитивному замыканию . | 
Алгоритм для антисимметричных отношений
Для удобства представим отношение в виде графа: . Его транзитивным остовом будет граф .
Введём несколько обозначений:
- — в графе есть ребро из вершины в ;
- — в графе есть путь (возможно, рёберно пустой) из вершины в ;
- — в графе есть рёберно непустой путь из вершины в .
Также введём определение транзитивного замыкания в терминах теории графов:
| Определение: | 
| Транзитивным замыканием графа называется граф , где . | 
 
Так как отношение антисимметрично, то граф ацикличен, то есть в нём выполняется следующее: .
Докажем теорему, из которой следует алгоритм.
| Теорема: | 
| Пусть . Тогда  | 
| Доказательство: | 
| Докажем, что : Пусть уже построен. Пусть . Тогда (так как иначе удаление ребра из приведёт к образованию меньшего графа с тем же транзитивным замыканием, что нарушает условие минимальности транзитивного остова). Поэтому по определению транзитивного остова . Пусть — вершина, для которой выполняется . Докажем, что , от противного. Пусть . ацикличен, поэтому . Поскольку , верно . Поскольку ацикличен, путь из в не может содержать ребра , аналогично путь из в не может содержать . Поэтому в существует путь из в , не содержащий в себе ребро , значит, удаление из не изменит транзитивное замыкание, что противоречит условию минимальности . Поэтому . Поскольку , существует такая вершина , что , что приводит к выводу, что . Докажем, что : Предположим, что и . Докажем, что , от противного. Предположим, что . Поскольку ацикличен, и поэтому . Поскольку , существует вершина такая, что и , поэтому . Поскольку ацикличен, существует вершина , для которой выполняется , что противоречит нашему предположению.Так как множества и включены друг в друга, они совпадают, то есть равны. | 
Псевдокод
= foreach in foreach in foreach in if and and .delete(pair, )
Источники информации
- Wikipedia: Transitive reduction
- J.A. La Poutré and J. van Leeuwen. «Maintenance of transitive closures and transitive reductions of graphs», 1987.
