Транзитивный остов — различия между версиями

Материал из Викиконспекты
Перейти к: навигация, поиск
(Алгоритм для антисимметричных отношений)
Строка 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> вершина <tex> l </tex> достижима из <tex> k ] \wedge (l, m) \in E \Longrightarrow k = l \} </tex>
+
<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> (k, m) </tex> из <tex> E' </tex> получится меньший граф с тем же транзитивным замыканием, что противоречит определению). Поэтому в пути от <tex> k </tex> к <tex> m </tex> в графе <tex> G </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> l </tex> такую, что <tex> l </tex> достижима из <tex> k </tex>, и есть ребро из <tex> l </tex> в <tex> m </tex>. Предположим, что <tex> k \neq l </tex>. Так как граф ацикличен, <tex> l \neq m </tex>. Так же так как транзитивное замыкание <tex> G </tex> равно транзитивному замыканию <tex> G' </tex>, в графе <tex> G' </tex> вершина <tex> l </tex> достижима из <tex> k </tex>, а <tex> m </tex> — из <tex> l </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) \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>, что противоречит нашему предположению.
Теперь предположим, что <tex> (k, m) \in E </tex>. Так как <tex> G </tex> ацикличен, <tex> k \neq m </tex> и отсюда в <tex> G' </tex> вершина <tex> m </tex> достижима из <tex> k </tex>. Поскольку <tex> (k, m) \notin E' </tex>, существует вершина <tex> l </tex> такая, что есть путь из <tex> k </tex> в <tex> l </tex> и из <tex> l </tex> в <tex> m </tex>, и <tex> k \neq l \neq m </tex>. Это значит, что в <tex> G </tex> что есть путь из <tex> k </tex> в <tex> l </tex> и из <tex> l </tex> в <tex> m </tex> (причём в каждом пути будет как минимум по одному ребру). Поскольку <tex> G </tex> ацикличен, это значит, что в <tex> G </tex> существует вершина <tex> l' </tex> такая, что есть путь как минимум в одно ребро из <tex> k </tex> в <tex> l' </tex> и есть ребро <tex> (l', m) </tex>. Это противоречит нашему предположению.
 
 
}}
 
}}
  

Версия 11:31, 12 апреля 2012

Определение:
Транзитивным остовом (transitive reduction) отношения [math] R [/math] на множестве [math] X [/math] называется минимальное отношение [math] R' [/math] на [math] X [/math] такое, что транзитивное замыкание [math] R' [/math] равно транзитивному замыканию [math] R [/math].


Алгоритм для антисимметричных отношений

Для удобства представим отношение в виде графа: [math] G = \left \lt V, E \right \gt [/math]. Его транзитивным остовом будет граф [math] G' = \left \lt V, E' \right \gt [/math].

Введём несколько обозначений:

  • [math] u \underset{G}{\longrightarrow} v [/math] — в графе [math] G [/math] есть ребро из вершины [math] u [/math] в [math] v [/math];
  • [math] u \underset{G}{\overset{*}{\longrightarrow}} v [/math] — в графе [math] G [/math] есть путь (возможно, пустой) из вершины [math] u [/math] в [math] v [/math] (то есть вершина [math] v [/math] достижима из [math] u [/math]);
  • [math] u \underset{G}{\overset{+}{\longrightarrow}} v [/math] — в графе [math] G [/math] есть непустой путь из вершины [math] u [/math] в [math] v [/math].

Также введём определение транзитивного замыкания в терминах теории графов:

Определение:
Транзитивным замыканием графа [math] G = \left \lt V, E \right \gt [/math] называется граф [math] G^* = \left \lt V, E^* \right \gt [/math], где [math] E^* = \left \{ (i, j) \in V \times V | i \underset{G}{\overset{*}{\longrightarrow}} j \right \} [/math].


Так как отношение антисимметрично, то граф ацикличен, то есть в нём выполняется следующее: [math] \forall i, j \in V: i \underset{G}{\overset{+}{\longrightarrow}} j \Longrightarrow i \neq j [/math].

Докажем теорему, из которой следует алгоритм.

Теорема:
[math] E' = \left \{ (k, m) \in E \ | \ \forall l: [ k \underset{G}{\overset{*}{\longrightarrow}} l \wedge (l, m) \in E \Longrightarrow k = l ] \right \} [/math]
Доказательство:
[math]\triangleright[/math]

Пусть [math] G' [/math] уже построен. Пусть [math] (k, m) \in E' [/math]. Тогда [math] k \neq m [/math] (т.к. граф ацикличен). Поэтому [math] k \underset{G}{\overset{+}{\longrightarrow}} m [/math]. Пусть [math] l [/math] — вершина, для которой выполняется [math] k \underset{G}{\overset{*}{\longrightarrow}} l \underset{G}{\longrightarrow} m [/math]. (Докажем, что [math] k = l [/math], от противного) Пусть [math] k \neq l [/math]. [math] G [/math] ацикличен, поэтому [math] l \neq m [/math]. Поскольку [math] G^* = (G')^* [/math], верно [math] k \underset{G'}{\overset{+}{\longrightarrow}} l \underset{G'}{\overset{+}{\longrightarrow}} m [/math]. Поскольку [math] G' [/math] ацикличен, путь из [math] k [/math] в [math] l [/math] не может содержать ребра [math] (k, m) [/math]. Аналогично путь из [math] l [/math] в [math] m [/math] не может содержать [math] (k, m) [/math]. Поэтому в [math] G' [/math] существует путь из [math] k [/math] в [math] m [/math], не содержащий в себе ребро [math] (k, m) [/math]. Поэтому удаление [math] (k, m) [/math] из [math] E' [/math] не изменит транзитивное замыкание, что противоречит условию минимальности [math] E' [/math]. Поэтому [math] \forall l: [ k \underset{G}{\overset{*}{\longrightarrow}} l \wedge (l, m) \in E \Longrightarrow k = l ] [/math]. Поскольку [math] k \underset{G}{\overset{+}{\longrightarrow}} m [/math], существует такая вершина [math] l [/math], что [math] k \underset{G}{\overset{*}{\longrightarrow}} l \underset{G}{\longrightarrow} m [/math], что приводит к выводу, что [math] (k, m) \in E [/math].

Предположим, что [math] (k, m) \in E [/math] и [math] \forall l: [ k \underset{G}{\overset{*}{\longrightarrow}} l \wedge (l, m) \in E \Longrightarrow k = l ] [/math], но [math] (k, m) \notin E' [/math]. (Докажем противоречие от противного) Поскольку [math] G [/math] ацикличен, [math] k \neq m [/math] и поэтому [math] k \underset{G'}{\overset{+}{\longrightarrow}} m [/math]. Поскольку [math] (k, m) \notin E' [/math], существует вершина [math] l [/math] такая, что [math] k \underset{G'}{\overset{*}{\longrightarrow}} l \underset{G'}{\overset{*}{\longrightarrow}} m [/math] и [math] k \neq l \neq m [/math]. Поэтому [math] k \underset{G}{\overset{+}{\longrightarrow}} l \underset{G}{\overset{+}{\longrightarrow}} m [/math]. Поскольку [math] G [/math] ацикличен, существует вершина [math] l' \neq k [/math], для которой выполняется [math] k \underset{G}{\overset{+}{\longrightarrow}} l' \underset{G}{\longrightarrow} m [/math], что противоречит нашему предположению.
[math]\triangleleft[/math]

Псевдокод

 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))

Источники