Die letzten 9 Beiträge |
AufgeschmissenerGast |
Zitat: |
Original von eulerscheZahl
T(n) = 4 T(n/2) + ... |
Dann hab ich da wohl einen Denkfehler. Ich dachte, es wird einfach der Integer T(n/2) einmal berechnet und die Ergebniszahl mit 4 multipliziert. |
eulerscheZahl |
T(n) = 4 T(n/2) + ... |
AufgeschmissenerGast |
Nicht wirklich. Also wenn ich mir die einzelnen Zeilen angucke, verstehe ich auch, wie sie auf die Zeiten rechts kommen.
Was ich jedoch auch nicht verstehe ist, wieso in der zweiten Zeile der Algorithmus 4 mal durchlaufen wird. Eigentlich wird er doch nur einmal für n/2 aufgerufen, und nicht 4 mal? |
eulerscheZahl |
Die Baumhöhe habe ich einfach als unendlich angenommen, die letzten Faktoren fallen sowieso kaum ins Gewicht (ersetzt man 4^k wieder durch n, gibt das eine Laufzeit von , die ersten beiden Summanden machen alleine schon ).
Sind in deinem Bild die Zeiten rechts (oberhalb des ) klar? |
AufgeschmissenerGast |
In einer Aufgabe, die so ähnlich war, also quasi als Beispiel auf einem Foliensatz diente, wurde nichtmal etwas umgestellt, berechnet oder ähnliches. Leider sind keine Beschreibungen dabei und deshalb verstehe ich nicht wie die darauf kommen.
Ich stelle das Bild mal ein.
Irgendwie sind die von der Rekursionsgleichung (oben) direkt auf die Laufzeit (unten rechts) gekommen.
AufgeschmissenerGast hat dieses Bild (verkleinerte Version) angehängt:
|
eulerscheZahl |
Die n/16 gibt es eindeutig öfter als 4 Mal.
Edit:
oder war es Absicht, dass mehr Klammer aufgehen als zu?
Wenn ja, kannst du den Faktor ja reinziehen und bist dann bei meiner Formel.
eulerscheZahl hat dieses Bild (verkleinerte Version) angehängt:
|
AufgeschmissenerGast |
Danke für deine Antwort! Aber wie kommst du auf diese Summanden?
Ich dachte die ersten Summanden müssten so aussehen
|
eulerscheZahl |
Schreibe dir mal die ersten Summanden hin:
lässt sich vereinfachen:
|
AufgeschmissenerGast |
Laufzeitbestimmung bei rekursiver Gleichung
Hallo Leute,
Ich sitze hier an einem Arbeitsblatt und komme nicht sehr weit. Genauer gesagt finde ich nichtmal einen Ansatz. Ich soll die Laufzeit bestimmen von folgender Rekursionsgleichung:
T(n) = 1 wenn n = 1
T(n) = 4 * T(n/4) + n^3 wenn n > 1
Sie dürfen annehmen, dass n von der Form 4^k ist.
Wie gehe ich da jetzt ran? Ich habe versucht die einzelnen Aufrufe zu zählen und die Höhe des "Baumes" zu bestimmen aber irgendwie steh ich voll aufm Schlauch.
Wäre super, wenn mir einer auf die Sprünge helfen könnte |