ue2
Aus ProgrammingWiki
< BuK | IIm11 | Studenten/sijeheid
Übung 2
Aufgabe 5
Verifizieren Sie, dass die folgende Funktion $f:\N^+ \rightarrow \Q^+$ eine bijektive Funktion ist und implementieren Sie eine Prozedur, die die zugehörige Umkehrfunktion $f^{-1}$ berechnet.
$$f(n) = \begin{cases} 1, & \text{wenn } n=1;\\ f(\frac{n}{2})+1, & \text{wenn } n \text{ gerade};\\ \frac{1}{f(n-1)}, & \text{wenn } n \text{ ungerade}. \end{cases}$$
- Schreiben Sie als erstes eine Scheme-Prozedur für $f$ und führen Sie einige rekursive Berechnungen aus.
- Berechnen Sie $f(n)$ für $n = 1,2,....,7$ mit Hand.
- Verbessern Sie die Effizienz der Prozedur für $f$ mittels memoizing.
Lösung zu 1.:
Lösung zu 2.:
$f(1) = 1$
$f(2) = 2$
$f(3) = 0,5$
$f(4) = 3$
$f(5) = \frac{1}{3}$
$f(6) = 1,5$
$f(7) = \frac{2}{3}$
Lösung zu 3.: