Транзитивный остов — различия между версиями
(→Алгоритм для антисимметричных отношений) |
|||
Строка 5: | Строка 5: | ||
== Алгоритм для антисимметричных отношений == | == Алгоритм для антисимметричных отношений == | ||
− | Для удобства представим отношение в виде графа: <tex> G = \left < V, E \right > </tex>. Его транзитивным остовом будет граф <tex> G' = \left < V, E' \right > </tex>. Так как отношение антисимметрично, то граф ацикличен. | + | Для удобства представим отношение в виде графа: <tex> G = \left < V, E \right > </tex>. Его транзитивным остовом будет граф <tex> G' = \left < V, E' \right > </tex>. |
+ | |||
+ | Введём несколько обозначений: | ||
+ | * <tex> u \underset{G}{\longrightarrow} v </tex> — в графе <tex> G </tex> есть ребро из вершины <tex> u </tex> в <tex> v </tex>; | ||
+ | * <tex> u \underset{G}{\overset{*}{\longrightarrow}} v </tex> — в графе <tex> G </tex> есть путь (возможно, пустой) из вершины <tex> u </tex> в <tex> v </tex> (то есть вершина <tex> v </tex> достижима из <tex> u </tex>); | ||
+ | * <tex> u \underset{G}{\overset{+}{\longrightarrow}} v </tex> — в графе <tex> G </tex> есть непустой путь из вершины <tex> u </tex> в <tex> v </tex>. | ||
+ | |||
+ | Также введём определение транзитивного замыкания в терминах теории графов: | ||
+ | {{Определение | ||
+ | |definition= | ||
+ | '''Транзитивным замыканием''' графа <tex> G = \left < V, E \right > </tex> называется граф <tex> G^* = \left < V, E^* \right > </tex>, где <tex> E^* = \left \{ (i, j) \in V \times V | i \underset{G}{\overset{*}{\longrightarrow}} j \right \} </tex>. | ||
+ | }} | ||
+ | |||
+ | Так как отношение антисимметрично, то граф ацикличен, то есть в нём выполняется следующее: <tex> \forall i, j \in V: i \underset{G}{\overset{+}{\longrightarrow}} j \Longrightarrow i \neq j </tex>. | ||
+ | |||
+ | Докажем теорему, из которой следует алгоритм. | ||
{{Теорема | {{Теорема | ||
|statement= | |statement= | ||
− | <tex> E' = \{ (k, m) \in E \ | \ \forall l: [ | + | <tex> E' = \left \{ (k, m) \in E \ | \ \forall l: [ k \underset{G}{\overset{*}{\longrightarrow}} l \wedge (l, m) \in E \Longrightarrow k = l ] \right \} </tex> |
|proof= | |proof= | ||
− | Пусть <tex> (k, m) \in E' </tex>. Тогда <tex> k \neq m </tex> ( | + | Пусть <tex> G' </tex> уже построен. Пусть <tex> (k, m) \in E' </tex>. Тогда <tex> k \neq m </tex> (т.к. граф ацикличен). Поэтому <tex> k \underset{G}{\overset{+}{\longrightarrow}} m </tex>. Пусть <tex> l </tex> — вершина, для которой выполняется <tex> k \underset{G}{\overset{*}{\longrightarrow}} l \underset{G}{\longrightarrow} m </tex>. (Докажем, что <tex> k = l </tex>, от противного) Пусть <tex> k \neq l </tex>. <tex> G </tex> ацикличен, поэтому <tex> l \neq m </tex>. Поскольку <tex> G^* = (G')^* </tex>, верно <tex> k \underset{G'}{\overset{+}{\longrightarrow}} l \underset{G'}{\overset{+}{\longrightarrow}} m </tex>. Поскольку <tex> G' </tex> ацикличен, путь из <tex> k </tex> в <tex> l </tex> не может содержать ребра <tex> (k, m) </tex>. Аналогично путь из <tex> l </tex> в <tex> m </tex> не может содержать <tex> (k, m) </tex>. Поэтому в <tex> G' </tex> существует путь из <tex> k </tex> в <tex> m </tex>, не содержащий в себе ребро <tex> (k, m) </tex>. Поэтому удаление <tex> (k, m) </tex> из <tex> E' </tex> не изменит транзитивное замыкание, что противоречит условию минимальности <tex> E' </tex>. Поэтому <tex> \forall l: [ k \underset{G}{\overset{*}{\longrightarrow}} l \wedge (l, m) \in E \Longrightarrow k = l ] </tex>. Поскольку <tex> k \underset{G}{\overset{+}{\longrightarrow}} m </tex>, существует такая вершина <tex> l </tex>, что <tex> k \underset{G}{\overset{*}{\longrightarrow}} l \underset{G}{\longrightarrow} m </tex>, что приводит к выводу, что <tex> (k, m) \in E </tex>. |
− | + | Предположим, что <tex> (k, m) \in E </tex> и <tex> \forall l: [ k \underset{G}{\overset{*}{\longrightarrow}} l \wedge (l, m) \in E \Longrightarrow k = l ] </tex>, но <tex> (k, m) \notin E' </tex>. (Докажем противоречие от противного) Поскольку <tex> G </tex> ацикличен, <tex> k \neq m </tex> и поэтому <tex> k \underset{G'}{\overset{+}{\longrightarrow}} m </tex>. Поскольку <tex> (k, m) \notin E' </tex>, существует вершина <tex> l </tex> такая, что <tex> k \underset{G'}{\overset{*}{\longrightarrow}} l \underset{G'}{\overset{*}{\longrightarrow}} m </tex> и <tex> k \neq l \neq m </tex>. Поэтому <tex> k \underset{G}{\overset{+}{\longrightarrow}} l \underset{G}{\overset{+}{\longrightarrow}} m </tex>. Поскольку <tex> G </tex> ацикличен, существует вершина <tex> l' \neq k </tex>, для которой выполняется <tex> k \underset{G}{\overset{+}{\longrightarrow}} l' \underset{G}{\longrightarrow} m </tex>, что противоречит нашему предположению. | |
− | |||
}} | }} | ||
Версия 11:31, 12 апреля 2012
Определение: |
Транзитивным остовом (transitive reduction) отношения на множестве называется минимальное отношение на такое, что транзитивное замыкание равно транзитивному замыканию . |
Алгоритм для антисимметричных отношений
Для удобства представим отношение в виде графа:
. Его транзитивным остовом будет граф .Введём несколько обозначений:
- — в графе есть ребро из вершины в ;
- — в графе есть путь (возможно, пустой) из вершины в (то есть вершина достижима из );
- — в графе есть непустой путь из вершины в .
Также введём определение транзитивного замыкания в терминах теории графов:
Определение: |
Транзитивным замыканием графа | называется граф , где .
Так как отношение антисимметрично, то граф ацикличен, то есть в нём выполняется следующее: .
Докажем теорему, из которой следует алгоритм.
Теорема: |
Доказательство: |
Пусть Предположим, что уже построен. Пусть . Тогда (т.к. граф ацикличен). Поэтому . Пусть — вершина, для которой выполняется . (Докажем, что , от противного) Пусть . ацикличен, поэтому . Поскольку , верно . Поскольку ацикличен, путь из в не может содержать ребра . Аналогично путь из в не может содержать . Поэтому в существует путь из в , не содержащий в себе ребро . Поэтому удаление из не изменит транзитивное замыкание, что противоречит условию минимальности . Поэтому . Поскольку , существует такая вершина , что , что приводит к выводу, что . и , но . (Докажем противоречие от противного) Поскольку ацикличен, и поэтому . Поскольку , существует вершина такая, что и . Поэтому . Поскольку ацикличен, существует вершина , для которой выполняется , что противоречит нашему предположению. |
Псевдокод
R' = R foreach a in X foreach b in X foreach c in X if aRb and bRc and aRc R'.delete(pair(a, c))
Источники
- Wikipedia: Transitive reduction
- J.A. La Poutré and J. van Leeuwen «Maintenance of transitive closures and transitive reductions of graphs», 1987