agt_exercise/übung_8/aufgabe_2.tex
2026-06-13 18:27:25 +02:00

25 lines
1.3 KiB
TeX

\section{Implementierung von \textsc{Contract}}
\begin{enumerate}
\item $G$ nach $H$ kopieren. \hfill $\Oh(1)$
\item Wenn $\abs{V_H} \leq 2$, dann ist die Zerlegung $\tup{S, T}$ von $G$,
die den beiden letzen Knoten in $H$ entspricht, das Ergebnis.
\label{step2}
\item Wähle eine Zufallszahl $z$ im Intervall $\interval{1; \abs{V_H}}$. \hfill $\Oh(1)$
\item Nimm den Knoten $a = V_H[z]$ und wähle eine Zufallszahl $z'$ im Intervall $\interval{1, \abs{Adj[a]}}$.
Nimm den Knoten $b = Adj_{z'}[a]$. \hfill $\Oh(1)$
\item Bestimme für jeden zu $a$ oder $b$ adjazenten Knoten $c_i$ die Anzahl der Kanten
zwischen $c_i$ und $a$ oder $b$. \hfill $\Oh(V_H) = \Oh(n)$.
\item Kontrahiere die Kante $ab$. Lösche dazu die Knoten $a, b$ sowie alle zu $a$ oder $b$ inzidenten Kanten. Da Mehrfachkanten als Zahl implementiert sind, sind
nur maximal 2 Einträge pro $c_i$ zu löschen. \hfill $\Oh(n)$
Füge einen neuen Knoten $d$ ein. Füge für jeden Knoten $c_i$ die vorher bestimmte Anzahl
an Kanten zwischen $c_i$ und $a$ oder $b$ als Kanten zwischen $c_i$ und $d$ ein.
\hfill $\Oh(n)$
\item Gehe zurück zu \autoref{step2}
\end{enumerate}
Da der Knoten $a$ durch eine gleichverteilte Zufallszahl $z$ ausgewählt wird und der
Knoten $b$ ebenfalls gleichverteilt ausgewählt wird, ist die Kante $ab$ ebenfalls
gleichverteilt ausgewählt.
\points{6}