Sortier algorithmen
-
Jester schrieb:
Nein. Quicksort ist O(n^2). O-Notation betrachtet den worst-case.
Minor Nitpick: O-Notation betrachtet eigentlich erstmal gar keine cases, und Quicksort "ist" auch nicht O(irgendwas). f(x) = O(g(x)) heisst nur, dass f nicht schneller wächst als g. Man kann also ohne weiteres sagen, die Laufzeit von Quicksort im Average-Case ist in O(n log n).
-
Bashar schrieb:
Jester schrieb:
Nein. Quicksort ist O(n^2). O-Notation betrachtet den worst-case.
Minor Nitpick: O-Notation betrachtet eigentlich erstmal gar keine cases, und Quicksort "ist" auch nicht O(irgendwas). f(x) = O(g(x)) heisst nur, dass f nicht schneller wächst als g. Man kann also ohne weiteres sagen, die Laufzeit von Quicksort im Average-Case ist in O(n log n).
Erstmals danke @Yankee für den ausführlichen Beitrag.
Unklarheiten:
Die Konstante c, wie lässt sich diese berechnen?
Und für was steht g?
-
@Bashar: hast recht. Mit der Zeit wird man da halt ein bißchen schludrig. Zu sagen, daß (der normale) Quicksort einen Aufwand von O(n*nog(n)) Schritten habe ist dennoch inkorrekt. Das wollte ich eigentlich nur zeigen. Aber ich sollte vielleicht trotzdem etwas mehr auf meine Notation achten.
-
Wenn wir schon beim Klugscheissern sind:
f(x) = O(g(x)) ist mathematisch falsch, denn O(g(x)) bezeichnet eine Menge. Es heisst also
f(x) Element O(g(x))@Ice-Tea:
g(x) ist etwa so etwas:
n^2
n*log(n)
n!c*g(x) ist die obere Schranke für eine Menge von Funktionen, wie oben beschrieben.
-
Jo, dann schieb ich vielleicht doch mal schnell die exakte Definition von O(g(x)) an.
eine Funktion f(x) ist in O(g(x)) :<=> es ex. c aus N und n0 aus N: für alle n>=n0: f(x) <= c*g(x)
Man fordert also, daß ein vielfaches von g(x) eine obere Schranke von f(x) ist.
Für f(x) in O(g(x)) schreibt man auch oft f(x) = O(g(x)). Hat sich halt so eingebürgert.
MfG Jester
-
Yankee schrieb:
Wenn wir schon beim Klugscheissern sind:
f(x) = O(g(x)) ist mathematisch falsch, denn O(g(x)) bezeichnet eine Menge. Es heisst also
f(x) Element O(g(x))@Ice-Tea:
g(x) ist etwa so etwas:
n^2
n*log(n)
n!c*g(x) ist die obere Schranke für eine Menge von Funktionen, wie oben beschrieben.
Ersteres ist nun klar.
Zu c :
Wie berechne ich c? Kann ich c beliebig wählen oder muss ich es berechnen?
In deinem Post hast du ja geschrieben "bei uns ist c=5" (woher hast du das genommen?)
-
wenn DU zeigen willst, daß eine Funktion f(x) in O(g(x)) ist, dann mußt Du ein solches c finden. Wie man das findet kann von Fall zu Fall recht unterschiedlich sein. Es kann ein beliebiger Wert sein, aber er muß konstant sein.
Zum Beispiel kann man zaigen, daß 3*n^2+5*n+17 in O(n^2) ist.
geht folgendermaßen: 3*n^2+5*n+17 <= 3*n2+5*n2+17*n^2 = 25*n^2, wähle also c=25. Das ist zwar für die meisten Fälle viel zu groß, ist aber egal. Hauptsache es gibt eines.
MfG Jester
-
Yankee schrieb:
Wenn wir schon beim Klugscheissern sind:
f(x) = O(g(x)) ist mathematisch falsch, denn O(g(x)) bezeichnet eine Menge. Es heisst also
f(x) Element O(g(x))Es ist in der Informatik durchaus üblich f(x) = O(g(x)) zu schreiben. Klugscheißerei ist hier also unangebracht.
-
Da wir im Mathe-Forum sind, habe ich ja auch geschrieben, dass es mathematisch falsch ist. Ausserdem sollte der Beitrag auch nicht so ganz ernst sein
-
Auf der von mir erwähnten Seite geht's noch um:
- Formeltransformation
- Master TheoremHat noch jemand Lust diese beiden Formeln zu erklären?
-
Öh, Lust nicht gerade. Leih dir Introduction to Algorithms von Cormen aus und schau es dir dort an. Das Mastertheorem wird darin sehr gut erklärt (mit Beweis!). Im Prinzip ist es nur ein Kochrezept zum abschätzen von Rekurrenzgleichungen der Form: bzw. , wobei a und b Konstanten ≥ 1 sind. Ich müsste es in meinen Unterlagen suchen und es dauert ziemlich lange das komplette Mastertheorem abzutechen... Vielleicht findest du ja bei google oder in dem von mir erwähnten Buch Hilfe.
EDIT: Einer der ersten Treffer bei google: http://www.soft.uni-linz.ac.at/Teaching/Begleitmaterial/Uebungen/_Algorithmen_und_Datenstrukturen_2/02 Rekurrenzen.pdf
-
MaSTaH schrieb:
Öh, Lust nicht gerade. Leih dir Introduction to Algorithms von Cormen aus und schau es dir dort an. Das Mastertheorem wird darin sehr gut erklärt (mit Beweis!). Im Prinzip ist es nur ein Kochrezept zum abschätzen von Rekurrenzgleichungen der Form: bzw. , wobei a und b Konstanten ≥ 1 sind. Ich müsste es in meinen Unterlagen suchen und es dauert ziemlich lange das komplette Mastertheorem abzutechen... Vielleicht findest du ja bei google oder in dem von mir erwähnten Buch Hilfe.
EDIT: Einer der ersten Treffer bei google: http://www.soft.uni-linz.ac.at/Teaching/Begleitmaterial/Uebungen/_Algorithmen_und_Datenstrukturen_2/02 Rekurrenzen.pdf
Ich werde das Theorem in erwähntem Buch nachschauen.
Nehmen wir wieder die Funktion von vorhin: f(x)=4*n+3
Ich möchte mit dem Master Theroem beweisen, dass diese Funktion in n^2 liegt.
Wie mache ich das?
Welche Werte muss ich für a und b einsetzen (Wie verwende ich die Formel)?
-
Geht nicht, weil sie nicht der Form des Mastertheorems entspricht.
Ganz einfache Übung:
Darauf kannst du sofort das Master-Theorem anwenden. Probier es einfach mal, ist nichts schweres dabei. Rechne einfach aus und schaue, welcher der 3 Fälle des Master-Theorems eintritt .
-
MaSTaH schrieb:
Geht nicht, weil sie nicht der Form des Mastertheorems entspricht.
Ganz einfache Übung:
Darauf kannst du sofort das Master-Theorem anwenden. Probier es einfach mal, ist nichts schweres dabei. Rechne einfach aus und schaue, welcher der 3 Fälle des Master-Theorems eintritt .
Einverstanden.
Aber irgendwie muss sich eine Funktion in die Form des Master-Theorems umformen lassen.
-
Nope, nicht immer. Aber es gibt andere Methoden um Rekursionsgleichungen anderer Form abzuschätzen (Induktion etc.).
-
Eine Funktion zwischen geschlossener und offener Form umformen.
Ich suche Beispiele dafür! Je mehr desto besser
-
MaSTaH schrieb:
Nope, nicht immer. Aber es gibt andere Methoden um Rekursionsgleichungen anderer Form abzuschätzen (Induktion etc.).
Gib mal ein Beispiel für eine Funktion, die sich in Form des Master Theorems umformen lässt.