Quicksort Problem

Shibas

Mitglied
Moin,

ich hab die Aufgabe bekommen den Quicksort Algorithmus nachzubauen, nerviger weise funktioniert meine version hinten und vorne nicht. Er wählt bei der verkleinerung der liste ein neues pivot element aber tauscht nie.


Java:
package core;

public class Sort {


	
public Sort()
{
	
}
//initialisierung
int links = 0;
int rechts = 0;
int pivot = 0;
double mitte = 0;
int länge = 0;
int i = 0; 
int j = 0; 
int k = 0; 
Daten temp=null;


//Sortier Algorithmus	
public Daten[] quicksort(Daten[] db)
{

länge=db.length-1;		

//sortierung links-------------------------------------------------------------------------------------
while(länge != 0)
{
	mitte=Math.ceil(länge/2);	
	länge=(int) mitte;
	pivot = db[(int) mitte].value[0];
	System.out.println("Pivot: "+db[(int) mitte].wort);

	k=0;
	while(i<j)
	{

//Finde Element größer Pivot
		i=0;
		while (db[i].value[0] < pivot && i < mitte-1)
			{
			i++;
			}	
		links=i;




//Finde Element kleiner Pivot
		j=db.length-1;

		while(db[j].value[0] > pivot && j > mitte)
		{

			j--;
		}
		rechts=j;	
	
//elemente vertauschen
		if(i<j)
		{	
			
			System.out.println("tausch");
			temp = db[links];
			db[links]=db[rechts];
			db[rechts]=temp;
			
		}

	k++;
	}	
}	


	

//Sortierung Rechts	------------------------------------------------------------------------

	
	
return db;
	
}
	
	
}

Der Code ist nur für die linke seite aber selbst da müsste sich ja nach den ersten durchläufen was tun.

Währe nett wenn mir einer sagen könnte wo ich da mist verbockt habe.


mfg

Shibas
 
S

SlaterB

Gast
keine Motivation, den Fehler selber zu finden?
in Zeile 35 hast du ein so schönes System.out.println(),
wieso machst du danach nicht weiter, prüfst jede Einzelheit des Codes danach,
was sind i, j am Anfang, welche Werte links, rechts werden gefunden, notfalls jeden Vergleich bis dahin einzeln

du hast doch sicher ein Beispiel was du dir mit deinen Augen angeschaut hast,
du siehst auch dass das Programm das richtige Pivot wählt, du weiß inzwischen sicher ziemlich genau, welche zwei Elemente als erstes vertauscht werden müssten,
du weißt welche Elemente davor links und rechts vielleicht übersprungen werden weil der Vergleich mit dem Pivot irgendwas ergibt was du dir hoffentlich nebenher schon überlegt hast,
je länger du nachdenkst desto genauer kannst du jeden einzelnen Millimeter des Programmablaufs genau vorhersagen
(so mache ich das ;) )

was spricht dagegen exakt dem tatsächlichen Programmlauf zu folgen und die nicht bedachten Unterschiede festzustellen und dann zu korrigieren,
entweder den Fehler im Code oder die eigene Vorstellung des Vorgangs und daraufhin ganz anderen Code?
 
Zuletzt bearbeitet von einem Moderator:

remy

Aktives Mitglied
oder mit einem Debug-Modus deiner IDE... bei Iterationen und Rekursion finde ich das noch einen Ticken hilfreicher, wenn mir die Ausgaben keinen Hinweis auf den Fehler geben. Da kannst du Schritt für Schritt nachvollziehen, was dein Algorithmus macht und welche Werte einzelne Variablen, Arrays, Collections... haben. Es hilft auch, sich ein einfaches Beispiel auszudenken und den Weg des Algorithmus aufzuschreiben, wie er denn richtig funktionieren sollte und dabei den Debugger laufen zu lassen. Wenn sich die Wege irgendwann unterscheiden, siehst du, an welcher Stelle der Fehler auftritt.

Und nein, ich habe auch keine Lust, den Fehler zu suchen :D
 

Andi_CH

Top Contributor
hm faszinierend das Ganze:

while(0<0)
dann wird gleich innerhalb der whilschleife das 0 nochmals auf 0 gesetzt.

Und das ist 00 ? (Weiss man heute überhaupt noch auf welcher Türe 00 stand? :D )

TO - kannst du mir mit einfachen Worten erklären wie Quicksort funktioniert?
Jede Wette sobald du es mir so erklärt hast, dass ich es verstehe, schaffst du auch die Implementation.
 
Ähnliche Java Themen
  Titel Forum Antworten Datum
M Quicksort Rang ausgeben Allgemeine Java-Themen 2
M Quicksort Partition Allgemeine Java-Themen 0
Zrebna Quicksort-Algorithmus - zufälliges Pivot wählen Allgemeine Java-Themen 6
Kirby.exe Quicksort Allgemeine Java-Themen 5
N Quicksort Programm hängt sich auf Allgemeine Java-Themen 6
D Pivot-Wahl beim QuickSort steigert die Effizienz, eine Lüge??? Allgemeine Java-Themen 17
D QuickSort (Pivotelement) Allgemeine Java-Themen 2
R Quicksort 3 Median funktioniert nur unzuverlässig Allgemeine Java-Themen 2
S Alphabetische sortierung mit Quicksort Allgemeine Java-Themen 10
S Frage zu dieser Quicksort Variante Allgemeine Java-Themen 2
G QuickSort Allgemeine Java-Themen 7
G ArrayList mit quicksort sortieren Allgemeine Java-Themen 9
D QuickSort, Interface Allgemeine Java-Themen 2
G QuickSort mit 2 Kriterien durchführen Allgemeine Java-Themen 12
krgewb Problem mit Umlauten und Eszett bei InputStream Allgemeine Java-Themen 3
Max246Sch Backtracking Problem Box Filler Allgemeine Java-Themen 6
NightVision402 VisualVM Startskript Problem Allgemeine Java-Themen 3
javaBoon86 Email Server Connection Problem Allgemeine Java-Themen 1
F Problem mit PDFBOX Library Allgemeine Java-Themen 1
A Java modul Problem Allgemeine Java-Themen 4
D Read JSON File Problem Allgemeine Java-Themen 9
urmelausdemeis Exception in thread "main" java.lang.Error: Unresolved compilation problem: Allgemeine Java-Themen 7
J Problem mit JasperReports Allgemeine Java-Themen 8
M log4j Problem mit jlink Allgemeine Java-Themen 19
8u3631984 Problem beim Mocken von Record Klassen Allgemeine Java-Themen 4
torresbig Website login Problem - Jsoup, wie bisher, klappt nicht! Allgemeine Java-Themen 31
P Selenium . getText Problem Allgemeine Java-Themen 9
A Jar zu Exe Problem Allgemeine Java-Themen 13
sserio Variablen Liste erstellt und ein Problem mit dem Index Allgemeine Java-Themen 6
S Folgendes Problem bei einem Programm Allgemeine Java-Themen 1
stormyark Problem beim Klassen erstellen Allgemeine Java-Themen 1
A Thread.sleep Problem Allgemeine Java-Themen 2
A Problem bei der Nachbarschafttest Allgemeine Java-Themen 11
Splayfer Problem: no main manifest attribute Allgemeine Java-Themen 3
G javamail Problem beim Empfangen von Nachrichten Allgemeine Java-Themen 3
Splayfer JDA Problem mit MessageCounter Allgemeine Java-Themen 0
Splayfer Problem mit BufferedWriter Allgemeine Java-Themen 3
F Streams als Alternative für dieses Problem ? Allgemeine Java-Themen 15
N Maven Problem mit Datenbanktreiber (H2 Embedded) Allgemeine Java-Themen 12
T Problem beim Umwandeln in eine Jar-Datei Allgemeine Java-Themen 3
B Einfach Elemente zweier Arraylisten kreuz und quer vergleichen, min und max Problem? Allgemeine Java-Themen 16
C ArrayList Problem Allgemeine Java-Themen 3
kev34 nim-Spiel problem Allgemeine Java-Themen 1
D Firebase retrieve data Problem, Child Element wird nicht angesprochen Allgemeine Java-Themen 0
G Welches Problem besteht bei den Typparametern? Allgemeine Java-Themen 5
temi Problem mit Aufrufreihenfolge bei Vererbung Allgemeine Java-Themen 3
Sumo_ow "ArrayIndexOutofBoundsException: 2" Array Problem Allgemeine Java-Themen 6
T PIM basierend auf netbeans via AnyDesk Problem Allgemeine Java-Themen 3
xGh0st2014 Problem mit Java Array Allgemeine Java-Themen 1
Kirby.exe Verständnis Problem bei Rucksack Problem Allgemeine Java-Themen 6
B Eclipse-Lombok-Problem Allgemeine Java-Themen 19
I Input/Output ObjectOutputStream - Problem Allgemeine Java-Themen 7
1 Multiple Choice Knapsack- Problem Allgemeine Java-Themen 2
kodela Problem mit strukturiertem Array Allgemeine Java-Themen 18
E Problem mit Gridlayout und Button Allgemeine Java-Themen 2
A Array Problem Allgemeine Java-Themen 8
bueseb84 Problem Allgemeine Java-Themen 0
S Problem mit Arrays Allgemeine Java-Themen 1
D Nullpointer Exception Problem Allgemeine Java-Themen 5
B Problem mit meinen Klassen Allgemeine Java-Themen 6
A HashMap Methode "get()"-Problem Allgemeine Java-Themen 28
J Problem beim Umstellen auf Java jdk 13 Allgemeine Java-Themen 3
J Problem bei Install java 13 Allgemeine Java-Themen 3
X Profitable Reise Problem Allgemeine Java-Themen 32
A Problem beim öffnen von Java-Installern Allgemeine Java-Themen 1
Dann07 Problem mit JavaMail API Allgemeine Java-Themen 26
J Problem beim Generischen Klassen und Interfaces Allgemeine Java-Themen 2
L Klassen Algorithmus für das folgende Problem entwickeln? Allgemeine Java-Themen 30
J Clear-Problem Allgemeine Java-Themen 10
B Problem zu einem Java Projekt Allgemeine Java-Themen 6
S JFileChooser Problem Allgemeine Java-Themen 4
M Traveling Salesman - MST Heuristik Problem Allgemeine Java-Themen 4
J Traveling Salesman Problem Allgemeine Java-Themen 14
E Java Editor Problem mit 2er Exceptions Allgemeine Java-Themen 12
C code oder Bibliotheken für 2-Center Problem Allgemeine Java-Themen 4
M Salesman Problem - Bruteforce Algorithmus Allgemeine Java-Themen 23
S Methoden Problem mit NullPointerException Allgemeine Java-Themen 9
Javafan02 Problem mit if-clause Allgemeine Java-Themen 17
J Lombok Problem mit Konstruktoren bei Verberbung Allgemeine Java-Themen 1
kodela Event Handling Problem mit der Alt-Taste Allgemeine Java-Themen 16
W Threads Problem Allgemeine Java-Themen 15
D (Verständnis-)Problem mit Unterklasse Allgemeine Java-Themen 4
S Problem mit Generic bei unmodifiableCollection Allgemeine Java-Themen 4
S jserialcomm Problem Allgemeine Java-Themen 1
Flynn Thread-Problem... Allgemeine Java-Themen 2
J Generische Interface - Problem Allgemeine Java-Themen 3
G Problem beim GUI Allgemeine Java-Themen 9
L Applet Problem "security: Trusted libraries list file not found" ? Allgemeine Java-Themen 7
A OOP Problem beim Berechnen der größten Fläche eines Ringes Allgemeine Java-Themen 19
T Problem mit externen Datenbankzugriff über SSH Tunnel Allgemeine Java-Themen 4
F Problem beim Einlesen einer Textdatei Allgemeine Java-Themen 12
S Java OpenOffice Problem mit Windows-Benutzerwechsel Allgemeine Java-Themen 19
K Threads RAM Problem Allgemeine Java-Themen 20
P Operatoren Problem mit Zähler in recursiver Schleife Allgemeine Java-Themen 2
C Int Problem Allgemeine Java-Themen 8
C J2V8 NodeJs Java Bride Problem und Frage!?!? Allgemeine Java-Themen 1
J Problem bei Hashmap Key-Abfrage Allgemeine Java-Themen 4
C Webseiten Programm problem Allgemeine Java-Themen 5
M LocalDate Problem Allgemeine Java-Themen 4
J "Problem Objektorientierung" Allgemeine Java-Themen 20

Ähnliche Java Themen

Neue Themen


Oben