Транзитивный остов — различия между версиями
Alexandra (обсуждение | вклад) |
Alexandra (обсуждение | вклад) (→Алгоритм для антисимметричных отношений) |
||
Строка 37: | Строка 37: | ||
Предположим, что <tex> k \underset{G}{\to} m </tex> и <tex> \forall l: [ k \underset{G}{\leadsto} l \wedge l \underset{G}{\to} m \Longrightarrow k = l ] </tex>. Докажем, что <tex> k G^- m </tex>, от противного. Предположим, что <tex> (k, m) \notin E^- </tex>. Поскольку <tex> G </tex> ацикличен, <tex> k \neq m </tex> и поэтому <tex> k \underset{G^-}{\overset{+}{\leadsto}} m </tex>. Поскольку <tex> (k, m) \notin E^- </tex>, существует вершина <tex> l </tex> такая, что <tex> k \underset{G^-}{\leadsto} l \wedge l \underset{G^-}{\leadsto} m </tex> и <tex> k \neq l \neq m </tex>, поэтому <tex> k \underset{G}{\overset{+}{\leadsto}} l \wedge l \underset{G}{\overset{+}{\leadsto}} m </tex>. Поскольку <tex> G </tex> ацикличен, существует вершина <tex> l' \neq k </tex>, для которой выполняется <tex> k \underset{G}{\overset{+}{\leadsto}} l' \wedge l' \underset{G}{\to} m </tex>, что противоречит нашему предположению. | Предположим, что <tex> k \underset{G}{\to} m </tex> и <tex> \forall l: [ k \underset{G}{\leadsto} l \wedge l \underset{G}{\to} m \Longrightarrow k = l ] </tex>. Докажем, что <tex> k G^- m </tex>, от противного. Предположим, что <tex> (k, m) \notin E^- </tex>. Поскольку <tex> G </tex> ацикличен, <tex> k \neq m </tex> и поэтому <tex> k \underset{G^-}{\overset{+}{\leadsto}} m </tex>. Поскольку <tex> (k, m) \notin E^- </tex>, существует вершина <tex> l </tex> такая, что <tex> k \underset{G^-}{\leadsto} l \wedge l \underset{G^-}{\leadsto} m </tex> и <tex> k \neq l \neq m </tex>, поэтому <tex> k \underset{G}{\overset{+}{\leadsto}} l \wedge l \underset{G}{\overset{+}{\leadsto}} m </tex>. Поскольку <tex> G </tex> ацикличен, существует вершина <tex> l' \neq k </tex>, для которой выполняется <tex> k \underset{G}{\overset{+}{\leadsto}} l' \wedge l' \underset{G}{\to} m </tex>, что противоречит нашему предположению. | ||
− | Так как множества <tex> E^- </tex> и <tex> \left \{ k \underset{G}{\to} m \ | \ \forall l: [ k \underset{G}{\leadsto} l \wedge l \underset{G}{\to} m \Longrightarrow k = l ] \right \} </tex> включены друг в друга, они совпадают, | + | Так как множества <tex> E^- </tex> и <tex> \left \{ k \underset{G}{\to} m \ | \ \forall l: [ k \underset{G}{\leadsto} l \wedge l \underset{G}{\to} m \Longrightarrow k = l ] \right \} </tex> включены друг в друга, они совпадают, то есть равны. |
}} | }} | ||
Версия 18:02, 8 января 2017
Определение: |
Транзитивным остовом (англ. transitive reduction) отношения на множестве называется минимальное отношение на такое, что транзитивное замыкание равно транзитивному замыканию . |
Алгоритм для антисимметричных отношений
Для удобства представим отношение в виде графа:
. Его транзитивным остовом будет граф .Введём несколько обозначений:
- — в графе есть ребро из вершины в ;
- — в графе есть путь (возможно, рёберно пустой) из вершины в ;
- — в графе есть рёберно непустой путь из вершины в .
Также введём определение транзитивного замыкания в терминах теории графов:
Определение: |
Транзитивным замыканием графа | называется граф , где .
Так как отношение антисимметрично, то граф ацикличен, то есть в нём выполняется следующее: .
Докажем теорему, из которой следует алгоритм.
Теорема: |
Пусть . Тогда |
Доказательство: |
Докажем, что :Пусть уже построен. Пусть . Тогда (так как иначе удаление ребра из приведёт к образованию меньшего графа с тем же транзитивным замыканием, что нарушает условие минимальности транзитивного остова). Поэтому по определению транзитивного остова .Пусть — вершина, для которой выполняется . Докажем, что , от противного. Пусть . ацикличен, поэтому . Поскольку , верно . Поскольку ацикличен, путь из в не может содержать ребра , аналогично путь из в не может содержать . Поэтому в существует путь из в , не содержащий в себе ребро , значит, удаление из не изменит транзитивное замыкание, что противоречит условию минимальности . Поэтому . Поскольку , существует такая вершина , что , что приводит к выводу, что .Докажем, что :Предположим, что Так как множества и . Докажем, что , от противного. Предположим, что . Поскольку ацикличен, и поэтому . Поскольку , существует вершина такая, что и , поэтому . Поскольку ацикличен, существует вершина , для которой выполняется , что противоречит нашему предположению. и включены друг в друга, они совпадают, то есть равны. |
Псевдокод
= foreach in foreach in foreach in if and and .delete(pair( , ))