Sortier algorithmen
-
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.