Praktische Grenzen der Berechenbarkeit
Inhaltsverzeichnis[Verbergen] |
Motivation
Bei der Entwicklung eines effizienten Algorithmus spielt die Komplexitätstheorie eine große Rolle. Sie dient der Bewertung von Programmen und ermöglicht den Vergleich verschiedener Algorithmen bezüglich ihrer Laufzeit oder ihrem Speicherbedarf. Hierzu führt man, in Anlehnung an die Mathematik, Funktionsklassen ein, um die Algorithmen zu klassifizieren.
Funktionsgraphen
Wie gut kennst du noch die Funktionsgraphen und Funktionsnamen? Ordne den Funktionsgraphen die zugehörigen Funktionsnamen und Funktionsterme zu!
PotenzfunktionExponentialfunktionLineare Funktion
Lineare Suche
Der unten stehende Algorithmus durchsucht ein gegebenes Array a nach einem Objekt x.
Algorithmus lineare_suche Eingabe: Ein Array a der Länge n und ein zu suchendes Objekt x Ausgabe true, wenn es ein j, 1 <= j <= n gibt mit a[j] = x j := 1 found := (a[j] = x) while (not found and j<n){ j:=j+1 found:=(a[j] = x) return found }
Der Algorithmus geht die Elemente des Arrays der Reihe nach durch. Dabei vergleicht er jedes Element mit dem Objekt x. Das Programm endet, sobald x gefunden oder das Ende des Arrays erreicht worden ist.
Zur Analyse der Laufzeit des Algorithmus zählt man die elementaren Rechenoperationen. Hierzu zählen:
- Vergleiche wie "<", ">", "=", "and", "not",...
- Wertzuweisungen wie ":="
- Rechenoperationen wie "+", "-", "*", "/",...
Die Zahl der benötigten Rechenoperationen hängt offensichtlich von der Größe des Array und ob bzw. an welcher Stelle im Array das Objekt x vorkommt.
Im besten Fall (englisch "best case") benötigt man also sechs elementare Rechenoperationen. Dies ist der Fall wenn das gesuchte Objekt im ersten Arrayfeld ist. Hier wird die while-Schleife nicht durchlaufen.
Im schlechtesten Fall wird die while-Schleife (n-1)-mal durchlaufen. Dies ist der Fall, wenn das gesuchte Objekt x überhaupt nicht im Array vorhanden ist. Dann benötigt man elementare Rechenoperationen.
Interessant ist auch der durchschnittliche Fall (englisch "average case"). Hier wird die durchschnittliche Laufzeit über alle Möglichkeiten unter Berücksichtung der Wahrscheinlichkeit für die Eingabe a gemittelt. Man benötigt im Durchschnitt Rechenschritte.
Mit wird die Anzahl der elementaren Rechenoperationen in Abhängigkeit von der Länge des Arrays bezeichnet.
Zusammenfassend erhalten wir:
Türme von Hanoi
Das Spiel Türme von Hanoi besteht aus drei Stäben A,B und C, auf die verschieden große, gelochte Scheiben gesteckt werden können. Ziel des Spieles ist es, denn Stapel von Stab A auf Stab C zu verschieben. Dabei darf immer nur eine Scheibe auf eine anderen Stab gesteckt werden, wobei auf dem Zielstab keine kleinere Scheibe sein darf. Die Scheiben sind auf jedem Stab also der Größe nach geordnet.
Zusatzinformation: [Anzeigen]
Wachstum von Funktionen
Gegeben sind die untenstehenden Funktionen. Ab welchem ganzzahligen ist das exponentielle Wachstum von schlechter als das polynomielle der Funktionen ?
(Hinweis: Stelle zur Bestimmung eine Wertetabelle auf oder löse die Aufgabe graphisch!)
Tabelle als Lückentext zum Ausfüllen
Reiskörner auf einem Schachbrett
Spielstellungen beim Schach
In den Nachrichten liest man von Zeit zu Zeit einen Artikel über Schach-Matches zwischen Schachgroßmeistern wie "Garri Kasparow" und Supercomputern wie "Deep Blue". Doch warum braucht man dazu Supercomputer? Und warum gewinnt der Computer nicht immer? Die Antwort auf diese Frage kannst du dir vielleicht schon nach dieser Aufgabe selbst beantworten!
Ein Computerschachprogramm baut sich für jede Spielsituation einen Spielbaum auf und analysiert mit diesem, welcher Zug den größten Erfolg bringt. Um die Größe eines solchen Spielbaums geht es in dieser Aufgabe:
- Wie viele Knoten hat ein Schachspielbaum, bei dem jeder Halbzug (d.h. schwarz oder weiß ist am Zug) 5 Zugmöglichkeiten hat und ein Spiel im Durchschnitt nach 60 Halbzügen beendet ist?
- Kann man diesen Spielbaum auf einer handelsüblichen Festplatte speichern, wenn pro Knoten des Spielbaums 1 Byte Speicherplatz benötigt wird?