added algo1 assignments 2-3 and 5-8
Some checks failed
build-latex / build (push) Has been cancelled

This commit is contained in:
Jonas_Jones 2025-06-20 22:47:54 +02:00
parent b5ef7d1944
commit 3076cc12e6
6 changed files with 1753 additions and 0 deletions

317
algo1/assignment2/main.tex Normal file
View file

@ -0,0 +1,317 @@
\documentclass[a4paper]{article}
%\usepackage[singlespacing]{setspace}
\usepackage[onehalfspacing]{setspace}
%\usepackage[doublespacing]{setspace}
\usepackage{geometry} % Required for adjusting page dimensions and margins
\usepackage{amsmath,amsfonts,stmaryrd,amssymb,mathtools,dsfont} % Math packages
\usepackage{tabularx}
\usepackage{colortbl}
\usepackage{listings}
\usepackage{amsmath}
\usepackage{amssymb}
\usepackage{amsthm}
\usepackage{subcaption}
\usepackage{float}
\usepackage[table,xcdraw]{xcolor}
\usepackage{changepage,titlesec,fancyhdr} % For styling Header and Titles
\pagestyle{fancy}
\usepackage{enumerate} % Custom item numbers for enumerations
\usepackage[ruled]{algorithm2e} % Algorithms
\usepackage[framemethod=tikz]{mdframed} % Allows defining custom boxed/framed environments
\usepackage{listings} % File listings, with syntax highlighting
\lstset{
basicstyle=\ttfamily, % Typeset listings in monospace font
}
\usepackage[ddmmyyyy]{datetime}
\geometry{
paper=a4paper, % Paper size, change to letterpaper for US letter size
top=2.5cm, % Top margin
bottom=3cm, % Bottom margin
left=2.5cm, % Left margin
right=2.5cm, % Right margin
headheight=25pt, % Header height
footskip=1.5cm, % Space from the bottom margin to the baseline of the footer
headsep=1cm, % Space from the top margin to the baseline of the header
%showframe, % Uncomment to show how the type block is set on the page
}
\lhead{ALGO-1\\Sommersemester 2024}
\chead{\bfseries{Übungsblatt 2}\\}
\rhead{7987847\\Jonas Werner}
\begin{document}
\section*{Aufgabe 2.1}
Verwenden Sie das Mastertheorem, um das Wachstum folgender rekursiver Funktionen T (n) asym-
ptotisch exakt zu bestimmen. Es kann angenommen werden, dass T (1) konstant und n eine Potenz
von b ist.
\subsection*{a)}
\[ T(n) = 4 \cdot T\left(\frac{n}{2}\right) + n \log^2 n \]
Daraus lassen sich folgende Werte ablesen:
\begin{itemize}
\item $a = 4$
\item $b = 2$
\item $t(n) = n \log^2 n$
\item $2 > k > 1$
\end{itemize}
Damit berechnen wir:
\[ \log_b a = \log_2 4 = 2 > k = 1 \]
Daraus folgt:
\[
\Rightarrow \text{Es tritt Fall (a) ein.}
\]
Somit gilt die folgende Gleichung:
\[ T(n) = \theta\left(n^{\log_{b}a}\right) = \theta\left(n^2\right)\]
\subsection*{b)}
\[ T(n) = 3 \cdot T\left(\frac{n}{9}\right) + \sqrt{12n} \]
Daraus lassen sich folgende Werte ablesen:
\begin{itemize}
\item $a = 3$
\item $b = 9$
\item $t(n) = \sqrt{12n}$
\item $k = \frac{1}{2}$
\end{itemize}
Damit berechnen wir:
\[ \log_b a = \log_9 3 = \frac{1}{2} = k = \frac{1}{2} \]
Daraus folgt:
\[
\Rightarrow \text{Es tritt Fall (b) ein.}
\]
Somit gilt die folgende Gleichung:
\[ T(n) = \theta\left(n^{\log_{b}a} \cdot \log_{b}n \right) = \theta\left(n^{\frac{1}{2}} \cdot \log_{9}n \right) = \theta\left(\sqrt{n} \cdot \log_{9}n \right)\]
\subsection*{c)}
\[ T(n) = 64 \cdot T\left(\frac{n}{16}\right) + n\sqrt[4]{n} \]
Daraus lassen sich folgende Werte ablesen:
\begin{itemize}
\item $a = 64$
\item $b = 16$
\item $t(n) = n \sqrt[4]{n}$
\item $k = 1$
\end{itemize}
Damit berechnen wir:
\[ \log_b a = \log_2 4 = \frac{3}{2} > k = 1 \]
Daraus folgt:
\[
\Rightarrow \text{Es tritt Fall (a) ein.}
\]
Somit gilt die folgende Gleichung:
\[ T(n) = \theta\left(n^{\log_{b}a}\right) = \theta\left(n^{\frac{3}{2}}\right)\]
\subsection*{d)}
\[ T(n) = 4 \cdot T\left(0.99n\right) + 1.01n \]
Daraus lassen sich folgende Werte ablesen:
\begin{itemize}
\item $a = 4$
\item $b = \frac{1}{0.99}$
\item $t(n) = 1.01n$
\item $k = 1$
\end{itemize}
Damit berechnen wir:
\[ \log_b a = \log_{\frac{1}{0.99}} 4 \approx 137.935 > k = 1 \]
Daraus folgt:
\[
\Rightarrow \text{Es tritt Fall (a) ein.}
\]
Somit gilt die folgende Gleichung:
\[ T(n) = \theta\left(n^{\log_{b}a}\right) = \theta\left(n^{\log_{(\frac{1}{0.99})}4}\right) \approx \theta\left(n^{137.935}\right)\]
\break
\section*{Aufgabe 2.2}
Wir betrachten den folgenden Algorithmus für eine ganzzahlige Eingabe $n > 0$:
\begin{verbatim}
x = 0;
for (i = 1; i <= n; i++) {
for (j = 1; j <= f(i); j++) {
x = x + 1;
}
}
\end{verbatim}
Bestimmen Sie für jede der folgenden Funktionen $f(i)$ den Wert der Variable $x$ nach Ende des
Algorithmus exakt.
\subsection*{a)}
$f(i) = \frac{c}{n}$ für ein $c \in \mathbb{N}$.
$x = \mathlarger{\mathlarger{\sum}}_{i=0}^{n}\frac{c}{n} = c \cdot \frac{n}{n} = c$
\subsection*{b)}
$f(i) = \binom{n}{i}$
$x = \mathlarger{\mathlarger{\sum}}_{i = 1}^{n} \frac{n!}{(n - i) \cdot i!} = 2^n - 1$ weil $\mathlarger{\mathlarger{\sum}}_{i = 0}^{n} \frac{n!}{(n - i) \cdot i!} = 2^n$ und $\binom{n}{0} = 1$
\subsection*{c)}
$f(i) = \frac{n}{3^i}$
$x = \mathlarger{\mathlarger{\sum}}_{i = 1}^{\log{n}}\frac{n}{3^i} = n \cdot \mathlarger{\mathlarger{\sum}}_{i = 1}^{\log{n}}\frac{1}{3^i}$
\break
\section*{Aufgabe 2.3}
Geben Sie für folgende rekursive Gleichungen eine $geschlossene Form$ an und beweisen Sie deren
Korrektheit mittels Induktion.\\
\subsection*{a)}
$T(2) = 2, T(n) = T(n - 2) + n$ für $n = 2k, k \in \mathbb{N}, k > 1$\\
$T(n) = T(n - 2) + n = n + (n - 2) + (n - 4) + ... + 2 = 2 + 4 + 6 + ... + n$
$\mathlarger{\mathlarger{\sum}}_{i = 1}^{n/2}2i = 2 \cdot \mathlarger{\mathlarger{\sum}}_{i = 1}^{n/2}i = 2 \cdot \frac{1}{2} \cdot \frac{n}{2} \cdot \left(\frac{n}{2} + 1\right) = \frac{n \cdot \left(n + 2\right)}{4}$\\
\begin{proof}[\unskip\nopunct]
Beweis durch Vollständige Induktion:\\
Induktionsanfang ($k = 2$):
$T(n) = T(2k) \Rightarrow T(2 \cdot 2) = \frac{4 \cdot \left(4 + 2\right)}{4} = 6$\\
Induktionsvorraussetzung:
$T(n) = \frac{n \cdot \left(n + 2\right)}{4}$, $T(2) = 2$\\
Induktionsschritt ($k \Rightarrow k + 1$):
$T(2\cdot(k + 1)) = 2 \cdot \mathlarger{\mathlarger{\sum}}_{i = 1}^{(2k + 2)/2}i = 2 \cdot \left(\mathlarger{\mathlarger{\sum}}_{i = 1}^{k}i + (2k + 2)\right) = \frac{2k \cdot \left(2k + 2\right)}{4} + 2k + 2 = \frac{2k \cdot \left(2k + 2\right)}{4} + \frac{8k + 8}{4} = \frac{(2k)^2 + 4k + 8k + 12}{4} = \frac{(2k + 2)(2k + 4)}{4}$
\end{proof}
\subsection*{b)}
$T(2) = 2, T(n) = 2 \cdot T(\sqrt{n})$ für $n = 2^{2^k}, k \in \mathbb{N}, k > 0$\\
$T(n) = 2 \cdot T(\sqrt{n} = 2 \cdot T\left(2^{2^{k - 1}}\right) = 2 \cdot ... \cdot T\left(2^{2^{k - k}}\right) = 2^k \cdot T(2) = 2^{k + 1}$
\begin{proof}[\unskip\nopunct]
Beweis durch Vollständige Induktion:\\
Induktionsanfang ($k = 1$):
$T(n) = 2^{2 + 1} = 8$\\
Induktionsvorraussetzung:
$T(n) = 2^{k + 1}$, $T(2) = 2$\\
Induktionsschritt ($k \Rightarrow k + 1$):
$T(k + 1) = T\left(2^{2^{k + 2}}\right) = 2 \cdot T\left(2^{2^{k + 1}}\right) = 2 \cdot 2^{k + 1} = 2^{k + 2}$
\end{proof}
\subsection*{c)}
$T(1) = 1, T(n) = n \cdot T(\frac{n}{2})$, für $n = 2^k, k \in \mathbb{N}, k > 0$\\
$T\left(2^k\right) = 2^k \cdot T\left(2^{k-1}\right) = 2^k \cdot 2^{k - 1} \cdot T\left(2^{k - 2}\right) = 2^k \cdot 2^{k - 1} \cdot ... \cdot 2^{k - k} = \frac{k(k + 1)}{2} \cdot T(1) = \frac{k(k + 1)}{2}$
\begin{proof}[\unskip\nopunct]
Beweis durch Vollständige Induktion:\\
Induktionsanfang ($k = 1$):
$T(n) = \frac{k1(1 + 1)}{2} = 1$\\
Induktionsvorraussetzung:
$T(2^k) = 2^{\left(\frac{k(k + 1)}{2}\right)}$, $T(2) = 2$\\
Induktionsschritt ($k \Rightarrow k + 1$):
$T(k + 1) = T\left(2^{k + 1}\right) = 2^{k + 1} \cdot T(2^k) = 2^k \cdot 2^{\left(\frac{k(k + 1)}{2}\right)} = 2^{\left(\frac{k(k + 1)}{2}\right) + (k + 1)} = 2^{\left(\frac{k(k + 1) + 2k + 2}{2}\right)} = 2^{\left(\frac{k^2 + 3k + 2}{2}\right)} = 2^{\left(\frac{(k + 1)(k + 2)}{2}\right)}$
\end{proof}
\break
\section*{Aufgabe 2.4}
Wir betrachten die folgenden Funktionen.
\begin{figure}[H] % This forces the figure to appear exactly here in the document
\begin{subfigure}[b]{0.4\textwidth}
\begin{verbatim}
int mod(int x, int y) {
while(x >= y)
x = x - y;
return x;
}
\end{verbatim}
\end{subfigure}
\hfill
\begin{subfigure}[b]{0.4\textwidth}
\begin{verbatim}
int ggT(int a, int b) {
if(a == 0) {
return b;
} else {
return ggT(mod(b, a), a);
}
}
\end{verbatim}
\end{subfigure}
\end{figure}
\subsection*{a)}
Begründen Sie, warum $ggT$ für positive ganze Zahlen $a$ und $b$ terminiert.\\
Nach jedem Rekursionsaufruf ist $b > a$ und die Reihenfolge der beiden Zahlen wird vertauscht, sodass nach dem jeweils nächsten Rekursionsschritt wieder $b > a$ wird, aber mit vertauschten Werten, sodass beide Werte kleiner werden bis einer der beiden gleich 0 wird. Dann endet die Rekursion.
\subsection*{b)}
Zeigen Sie, dass $a + (b \mod{a}) \leq \frac{2}{3} \cdot (a + b)$, falls $0 < a \leq b.$\\
Sei $r = b \mod a$\\
$\Rightarrow b = ka + r$ für $k \geq 1$
\begin{align*}
a + r &\leq \frac{2}{3} \cdot (a + b) \\
a + r &\leq \frac{2}{3} \cdot ((k + 1)a + r)\\
3a + 3r &\leq 2(k + 1)a + 2r\\
0 &\leq 2ka (a + r)\\
0 &\leq 2ka 2a
\end{align*}
Da $k \geq 1$ gilt die Ungleichung und $a + (b \mod{a}) \leq \frac{2}{3} \cdot (a + b)$ ist bewiesen.
\subsection*{c)}
Bestimmen Sie die Worst-Case-Laufzeit $T(n)$ der Funktion $ggT$. Definieren Sie dafür zunächst
die Variable $n$ in Abhängigkeit von $a$ und $b$ und stellen Sie eine Rekursionsgleichung auf.\\
Beim Aufruf mit $mod(n, 1)$ wird die mod-Funktion n viele Schritte machen, weil in jeder Schleifenausführung $n - 1$ gerechnet wird, bis $n < 1$, also gleich 0 ist.
\subsection*{d)}
In Aufgabenteil $b)$ haben wir $a \leq b$ vorausgesetzt. Ändert sich $T(n)$ wenn wir $a \leq b$ nicht
mehr fordern? Begründen Sie Ihre Antwort.\\
Wenn $a \leq b$ nicht mehr vorrausgesetzt ist, also $a > b$ sein kann, so wird die mod-Funktion mit $a > b$ aufgerufen und die while-Schleife direkt übersprungen weil die $a = y, b = x$ und die Vorraussetzung des Schleifenaufrufs $x >= y$ nicht erfüllt ist. Somit kommt ein Rekursionsaufruf von $ggT()$ dazu, indem die Reihenfolge der beiden Zahlen "berichtigt", also in sofern angepasst wird, dass die Funktion ab dann normal ausgeführt wird, so wie als würde $a \leq b$ gelten.
\end{document}