Eine Frage zum Quicksort

Katzenstreik

Mitglied
Hallo miteinander,

ich beschäftige mich gerade mit dem Quicksort und stelle mir folgende Frage:

Ich zerteile eine Folge von Elementen ja in zwei Teile, indem ich das mittlere Element (also n/2) dafür nehme. Es ist doch durchaus möglich das das n/2te Element das kleinste oder meinetwegen fast das kleinste Element ist, wenn ich z.b. von dieser Folge ausgehe: Folge= {3,7,2,4,1,10,6,3,9}

Hierbei müsste ich dann doch alle Elemente in die zweite, also rechte hälfte transportieren.

So macht der Quicksort doch keinen Sinn mehr oder wenn das mittlere nur fast das kleineste ist, nur wenig Sinn. Warum wird in Büchern genau diese Vorgehensweise beschrieben? Gibt es keine bessere oder versteh ich was falsch?

Danke für eure Antworten.
 

Katzenstreik

Mitglied
naja, die Zeitkomplexität beträgt dann n^2 und ist somit nicht besser als einfache andere Sortierverfahren.

Worum es mir geht ist, ob es nicht mehr Sinn macht die Folge anders zu teilen, als mit n/2.
 

Final_Striker

Top Contributor
QS hat halt in Worst-Case eine Komplexität von n^2, da kannst du auch nichts daran ändern. Da haben sicher schon genug schlaue Köpfe sich Gedanken darum gemacht. ;-)
 
N

nununana

Gast
Eine Verbesserung liegt in der Wahl des Pivotelements. z.B. bildet man aus 3 Elementen den Median. Oder man wählt das Pivotelement zufällig. Das Mittlere wird oft gewählt, weil es dann mit bereits sortierten Folgen keine Probleme gibt. Gibt es viele gleiche Elemente, ist es besser, ein anderes Verfahren zu wählen.
 

Ezra

Bekanntes Mitglied
Das gibt es. Man kann den Median bestimmen: Median-Algorithmus
Dann wird die Laufzeitkomplexität auf O(n) reduziert.

Allerdings ist der konstante Faktor so groß, dass sich ein derartiges Verfahren nur bei wirklich großen n lohnt.

Edit:
z.B. bildet man aus 3 Elementen den Median. Oder man wählt das Pivotelement zufällig.
Das verbessert die Laufzeitkomplexitätsklasse für den worst case aber nicht.
Auch für ein zufällig gewähltes Pivot besteht die Möglichkeit, eine worst-case-Folge zu treffen.
Beim Median aus drei Elementen reduzierst Du höchstens den konstanten Faktor.
 
Zuletzt bearbeitet:

Katzenstreik

Mitglied
den median zu bilden find ich gut. Auch gut finde ich dass du gleich darauf hinweist, dass dies bei(fast)sortierten Folgen nachteilig zu bewerten ist.

Also kann man sagen, dass wenn man seine Folge nicht kennt die Wahl des Pivotelements ein Glücksspiel darstellt :)

(Obwohl ich persönlich einen Median immer bevorzugen werde...)

Danke Leute!
 

Ezra

Bekanntes Mitglied
Entweder verstehe ich Dich falsch oder Du mich.
Wo geht es denn um sortierte Folgen? Bei Quicksort mit n/2 als Pivot ist es nicht die sortierte Folge, die den worst case liefert. Das beste Beispiel dafür steht im Ausgangspost des TE.
Wenn Du nun behauptest, ein zufälliges Pivot sei besser als n/2 als Pivot, kann ich Dir nicht zustimmen. Die Wahrscheinlichkeiten, in den jeweiligen Fällen genau den worst case zu erwischen, sind gleich.

Auch gut finde ich dass du gleich darauf hinweist, dass dies bei(fast)sortierten Folgen nachteilig zu bewerten ist.
Das habe ich nicht gesagt. Ich sprach von kleinen Folgen (kleines n).
 
Zuletzt bearbeitet:
N

nununana

Gast
jaaa, missverständnisse. wird als pivot immer das erste/letzte element der teilfolge zurückgegeben, ist das schlecht. das kann passieren, wenn erstes oder letztes als pivot gewählt wird UND die folge bereits sortiert is.
um das zu vermeiden, nimmt man die mitte. man kann auch zufälliges element wählen. natürlich gibt es keinen unterschied in der wahrscheinlichkeit (mind. 2/n mal 2/(n-1) usw.), die der worst case hat. aber man kann davon ausgehen, dass öfters als sonst die sortierte folge sortiert werden soll.
TE hat ja auch gefragt, wie man pivot alles wählen kann. da hab ich mich hauptsächlich auf wiki gestützt, wo das auch erwähnung findet (n/2, zufällig, 3 elemente, alle usw.). vor-/nachteile muss man dann eben versuchen zu erklären oder in der praxis herausfinden.
 
Ähnliche Java Themen
  Titel Forum Antworten Datum
J Eine konzeptionelle Frage zu OOP Java Basics - Anfänger-Themen 3
J Eine theoretische Frage zur Praxis - JPanel oder Canvas Java Basics - Anfänger-Themen 5
Bademeister007 Hallo Leute ich hab eine Frage zur ArrayList Java Basics - Anfänger-Themen 8
N Input/Output Eine Frage über system.out.println. Java Basics - Anfänger-Themen 10
J Eine Frage zur Schreibweise == ? : Java Basics - Anfänger-Themen 3
O Bedingter Operator eine Frage! Java Basics - Anfänger-Themen 10
S Noch eine Frage zur Rekursion... Java Basics - Anfänger-Themen 11
M Eine Frage zu Array Java Basics - Anfänger-Themen 6
J Eine Frage zu Serializable Java Basics - Anfänger-Themen 3
L Erneut eine Frage zu Rückgabewerten Java Basics - Anfänger-Themen 10
J Ergebnis wird gespammt sowie eine else if Frage Java Basics - Anfänger-Themen 2
V in diesem Forum wurde mir am meisten geholfen, daher eine Frage die hier nicht passt. sry (VB Frage) Java Basics - Anfänger-Themen 3
E Methoden Eine Frage zum beigelegten "Programm" Java Basics - Anfänger-Themen 2
T Eine kurze frage vor der prüfung bitte. Java Basics - Anfänger-Themen 5
N Java UML: Eine Frage zu public-Variablen Java Basics - Anfänger-Themen 19
DaniSahne96 Frage zu Java ist auch eine Insel Java Basics - Anfänger-Themen 12
F Eine Frage über paint() Funktion Java Basics - Anfänger-Themen 2
A Eine Frage zu AWt in JAVA, wie wähle ich ein Punkt aus`? Java Basics - Anfänger-Themen 4
D Wohl eine einfache Frage... Java Basics - Anfänger-Themen 2
U actionListener - eine Kleine Frage Java Basics - Anfänger-Themen 7
B Eine Frage des Designs Java Basics - Anfänger-Themen 6
P Eine Frage begzl. Interface / Polymorphie Java Basics - Anfänger-Themen 11
L eine richtige anfänger-frage Java Basics - Anfänger-Themen 3
J Eine saudumme Frage Java Basics - Anfänger-Themen 5
T Eine doofe Frage zum null-Layout-Manager Java Basics - Anfänger-Themen 6
Screen Eine Frage zu moueMove in applets und deren Vergleich Java Basics - Anfänger-Themen 11
0 Eine Frage zur Vererbung... Java Basics - Anfänger-Themen 2
T Frage aus dem Buch JAVA ist auch eine Insel Java Basics - Anfänger-Themen 11
M Eine kleine Frage bzw kleine Theorie frage String[arg] Java Basics - Anfänger-Themen 6
G Frage:Welche Methodne kann man eine Zahl bzw. ein String Java Basics - Anfänger-Themen 3
P Eine kleine Frage. Java Basics - Anfänger-Themen 4
D Hab mal eine Frage. ganz leicht wahrscheinlich :D Java Basics - Anfänger-Themen 6
R eine frage wegen methoden und if statments Java Basics - Anfänger-Themen 6
B eine billige frage, für mich leider jedoch nicht Java Basics - Anfänger-Themen 16
R Noch eine Frage: Breite des Applets im Browser ermitteln Java Basics - Anfänger-Themen 7
R Habe ein Problem und eine Frage Java Basics - Anfänger-Themen 19
O eine frage/problem zu string.split() Java Basics - Anfänger-Themen 2
N Und noch eine Frage über getRuntime() Java Basics - Anfänger-Themen 4
S Nochmel eine Zugriffsfrage! FRAGE 2! Java Basics - Anfänger-Themen 3
T Newbie Frage Eine Java Anwendung fernsteuern? Java Basics - Anfänger-Themen 4
G eine Frage zur Generic Java ? Java Basics - Anfänger-Themen 8
D Eine GANZ dumme Frage Java Basics - Anfänger-Themen 22
Kerstininer Vererbung Hilfe beim lernen von Objektorientierung für eine Klausur Java Basics - Anfänger-Themen 10
K Warum wird hier nur etwas in eine txt Datei geschrieben und nicht in alle drei (InputStream/OutputStream/Reader/Writer) Java Basics - Anfänger-Themen 1
I In unterschiedlichen Applikation Zugriff auf eine gemeinsame Anwendung? Java Basics - Anfänger-Themen 8
D 2 ArrayListen gleich sortieren bzw. eine Liste anhand einer anderen Sortieren Java Basics - Anfänger-Themen 6
T Ich brauche eine Schleife die eine beliebige Zahl so lange durch 10 teilt bis zur Null Java Basics - Anfänger-Themen 5
S Java: Wie sortiere ich eine ArrayList benutzerdefinierter Objekte nach einem bestimmten Attribut? Java Basics - Anfänger-Themen 2
N Ich kriege ganze zeit die Fehlermeldung "Inhalt der Zwischenablage kann nicht in die ausgewählten Elemente eingefügt werden" hat jemand eine Lösung? Java Basics - Anfänger-Themen 6
M Vergleichen, ob eine Liste länger als andere ist Java Basics - Anfänger-Themen 6
T Methode soll etwas ausrechnen und zurückgeben (klappt nd) hat wer eine Idee? Java Basics - Anfänger-Themen 11
Shadowrunner Variablen Gibt es eine Möglichkeit die Ziffern/Stellen einer Zahl fest zu legen? Java Basics - Anfänger-Themen 3
Kingdako Wie löse ich eine Mathematische Formel mit Arrays und Schleifen? Java Basics - Anfänger-Themen 32
M Datentypen While-Schleife eine Java Methode erstellen Java Basics - Anfänger-Themen 3
G Wie wartet man bis ein URL eine Antwort zurückgibt? Java Basics - Anfänger-Themen 5
berserkerdq2 Intelij, wie kann ich einstellen, dass die aktuelle Klasse ausgeführt wird, wenn ich aufs Startsymbol drücke, gibts da eine Tastenkombination? Java Basics - Anfänger-Themen 11
S 2 Reihen ratio-btn, eine Reihe funktioniert andere nicht Java Basics - Anfänger-Themen 4
T Eingabe durch eine Zahl dividieren nachgucken? Java Basics - Anfänger-Themen 4
M mit Maven eine ausführbare Jar bauen Java Basics - Anfänger-Themen 7
P Java Selenium . Parameterized.Parameters erzeugt eine Fehlermeldung Java Basics - Anfänger-Themen 14
J Zugriff auf eine 2. Klasse die per UI-Designer erstellt wurde Java Basics - Anfänger-Themen 1
M Eine Funktion zuweisen Java Basics - Anfänger-Themen 3
A Methoden Guten Tag , ich wollte so machen dass wenn meine frog an eine fly/bee geht dann an meine Tafel geht der zahl +1 hoch. Java Basics - Anfänger-Themen 2
A Wie führe ich eine Batch-Datei von meiner Java-Anwendung aus? Java Basics - Anfänger-Themen 18
J Beim Start des Programms zB. eine Linie in JPanel ausgeben Java Basics - Anfänger-Themen 4
L Methoden Eine Methode um zu testen ob es ein Nachbar gibt Java Basics - Anfänger-Themen 10
S Eine Idee umsetzen ganz schnell!? Java Basics - Anfänger-Themen 68
I Grundsatzfrage: Belegt eine Referenz auf 'null' RAM, und wenn ja - wieviel ;-) ? Java Basics - Anfänger-Themen 5
jeff98 Wie kann man in Java eine Zeichenformation ausgeben? Java Basics - Anfänger-Themen 9
K loop pausieren für eine bestimmte Anzahl? Java Basics - Anfänger-Themen 1
_user_q Wie eine Methode/Funktion aus einer Klasse mit Constructor aufrufen? Java Basics - Anfänger-Themen 20
Thomas06 Wie kann man mithilfe von boolean herausfinden ob eine zahl durch 5 und 7 teilbart ist ? Java Basics - Anfänger-Themen 7
M Prüfen on eine Zahl im String enthalten ist Java Basics - Anfänger-Themen 3
U jUnit 5 Test für eine addMethode Java Basics - Anfänger-Themen 18
frager2345 Singleton-Muster Java ->Nur eine Instanz einer Klasse erzeugen können Java Basics - Anfänger-Themen 45
A Eclipse IDE - Wie bekomme ich eine ältere Version Java Basics - Anfänger-Themen 6
F Wie kann ich eine Funktion schreiben, die nur in bestimmten Fällen einen Wert zurückgibt? Java Basics - Anfänger-Themen 5
berserkerdq2 Warum muss man manchmal in der RUnmethode sleep in eine schleife tun? Java Basics - Anfänger-Themen 9
berserkerdq2 Findet eine parallele Verarbeitung in Java bei Threads erst statt, wenn man die Methoden auch synchronized? Und wie sieht bei Conditions aus? Java Basics - Anfänger-Themen 8
berserkerdq2 Wozu benötigt man den BiPredicate, kann ich nicht einfach eine normale Methode nutzen, statt BiPredicate? Java Basics - Anfänger-Themen 3
berserkerdq2 Habe eine Klasse, welche public ist, diese hat eine public Methode, die nicht static ist. Wenn ich nun versuche aufzurufen Probleme? Java Basics - Anfänger-Themen 8
berserkerdq2 Zwei Klassen Erben von der Klasse A, die eine Klasse kann ich an Methoden übergeben, die als Parameter A haben, die andere nicht? Java Basics - Anfänger-Themen 3
berserkerdq2 Sende eine Nachricht an den Client und leere den Ausgabestorm, was ist damit genau gemeint? Java Basics - Anfänger-Themen 3
S Eine Variable in einem Array speichern Java Basics - Anfänger-Themen 5
sserio Prüfen, ob eine Zahl eine periodische Zahl ist Java Basics - Anfänger-Themen 20
L Anpassung der Spaltenbreite auch auf eine zweite Tabelle anwenden Java Basics - Anfänger-Themen 8
NadimArazi Wie kann ich eine collision detection für die Paddles in meinem Pong Programm hinzufügen? Java Basics - Anfänger-Themen 4
JordenJost Java ist auch eine Insel für Anfänger Java Basics - Anfänger-Themen 2
berserkerdq2 Warum soll ich shuffle nutzen, um bei Rückgabewert Collection eine Liste zurückzugeben? Java Basics - Anfänger-Themen 3
berserkerdq2 Ich gebe eine ArrayList als List zurück per MEthode, wie kann ich nun aber die ArrayList speichern? Java Basics - Anfänger-Themen 46
berserkerdq2 Überprüfen ob eine Schreibberechtigung auf ein file exisitert bzw. ob man dieses file löschen kann, wie? Java Basics - Anfänger-Themen 9
sserio Java Fx, wie erstellt man einen EventHandler, der durch das Drücken eines Button Texte in eine Table view einfügt Java Basics - Anfänger-Themen 17
M Eine Methode die erkennt ob die ein gegebene zahl größer oder kleiner sein muss Java Basics - Anfänger-Themen 2
Avalon Warum funktioniert eine Bedingung und eine andere nicht? Java Basics - Anfänger-Themen 2
F Suche nach betreuender Person für eine Jahresarbeit der 12. Klasse. Java Basics - Anfänger-Themen 6
X Hilfe beim Übertragen in eine For-Schleife Java Basics - Anfänger-Themen 1
H Eine Methode über Actionlistener beenden Java Basics - Anfänger-Themen 8
A Wenn eine Zahl durch 7 teilbar ist, soll statt der Zahl ein ‘*‘ angezeigt werden. java? Java Basics - Anfänger-Themen 47
U Warum gibt das eine Nullpointerexception? (Switch) Java Basics - Anfänger-Themen 6
U Warum kriege ich hier eine nullpointer exception, sehe den Fehler nicht (swing) Java Basics - Anfänger-Themen 1

Ähnliche Java Themen

Neue Themen


Oben