Fehler in meinem Quicksort!

Status
Nicht offen für weitere Antworten.

mamelinchen

Bekanntes Mitglied
Mein Quicksort:

Code:
package a01;

public class QuickSortVerfahren {
	
	public static void tauscheWerte(int[]stapel,int a, int b){
		int helper=stapel[a];
		stapel[a]=stapel[b];
		stapel[b]=helper;
	}
	/******************************************************
	* Funktion zur Sortierung eines Feldes austeigend
	* Parameter:
	* @param- stapel: das zu sortierende Feld
	* @param- anfang: der Anfangswert des Feldes stapel
	* @param- ende:  der Endwert des Feldes stapel
	* Vorbedingung: R ist aufsteigend sortiert
	* @returnReturn: Sortiertes Feld aufsteigend,wenn Feld leer oder Größe 1,
	* dann wird das Feld stapel zurückgegeben
	* Effekt: -
	*****************************************************/
	

	public static void QuickSort(int[]stapel,int anfang,int ende){
		while (ende>anfang){
		
			int pivot=stapel[stapel.length-1];
			int j=ende;
			int i=anfang;
			
		while(i<=ende){
			i++;
		
			while(j>=anfang){
				j--;
		
				if(stapel[i]>pivot){// Wenn linkes El. grösser als Pivot und rechtes El.kleiner, dann tausche beide
					if(stapel[j]<pivot){
						System.out.println("JAJAJAJA");
						tauscheWerte(stapel,i,i);	
					}
				}
			}
		}
		if(i>=j){
			tauscheWerte(stapel,i,pivot);
			}
		QuickSort(stapel,anfang,pivot-1);
		QuickSort(stapel,pivot+1,ende);
		}
	}
	
	
	public static void main(String[] args) {
		int[]kleinarray=FileIntArray.FileToIntArray("../ALG1/src/a01/Rand20_1");
		QuickSort(kleinarray,0,19);
		for(int i=1;i<kleinarray.length;i++){
			System.out.println(kleinarray[i]);
		}
	}
}

Bloß das sich ein dummer Fehler eingeschlichen hat, und ich ihn net sehe.....!

Kann mir jemand weiterhelfen?
 
M

MiDniGG

Gast
Also bei mir wirfts da eine Exception nach der anderen. Erstmal kommt ne ArrayIndexOutOfBounds. Mach ich die weg kommt se wo anders wieder. Mach ich dann weiter und kommentier bissl was aus kommt ne StackOverflow, wegen dem rekursiven Aufruf der Quicksort-Methode...
Der Aufruf in der main-Methode ist auch nicht so geschickt, denn wenn mal mehr oder weniger als 19 zahlen im array stehen isses auch fürn arsch. da wäre ein kleinarray.length besser. So am Rande :)
 
M

MiDniGG

Gast
Naja. Dafür gibt's ja die Konsole die Dir alle Fehler rausschreibt ;)
 

mamelinchen

Bekanntes Mitglied
Habs anders gemacht, geht aber immer noch nicht!

StackOverFlowError......:(

Code:
	public static void tauscheWerte(int[]stapel,int a, int b){
		int helper=stapel[a];
		stapel[a]=stapel[b];
		stapel[b]=helper;
	}
	/******************************************************
	* Funktion zur Sortierung eines Feldes austeigend
	* Parameter:
	* @param- stapel: das zu sortierende Feld
	* @param- anfang: der Anfangswert des Feldes stapel
	* @param- ende:  der Endwert des Feldes stapel
	* Vorbedingung: R ist aufsteigend sortiert
	* @returnReturn: Sortiertes Feld aufsteigend,wenn Feld leer oder Größe 1,
	* dann wird das Feld stapel zurückgegeben
	* Effekt: -
	*****************************************************/
	

	public static void QuickSort(int[] stapel, int anfang, int ende) {
		if (ende > anfang) {
			int pivot = stapel[stapel.length - 1];
			int i = anfang;
			int j = ende - 1;

			while (i <= j) {

				while (stapel[i] < pivot) {
					i++;
				}
				while (stapel[j] > pivot) {
					j--;
				}
				if (i <= j) {
					System.out.println("JAJAJAJA");
					tauscheWerte(stapel, i, j);
					i++;
					j--;
				}
			}
			if (i >= j) {
				tauscheWerte(stapel, i, pivot);
			}
			QuickSort(stapel, anfang, i);
			QuickSort(stapel, i + 1, ende);
		}
	}

WO ist der Fehler?
 
M

MiDniGG

Gast
Ich hab kein Plan und will mich jetzt nicht reindenken. Aber vllt hilft Dir ja mein Code den ich irgendwann mal geschrieben hab ^^

Java:
	public static int[] quickSortAlgo(int[] arr) {
		int wert = getPivotElement(arr);
		int[] links = new int[arr.length];
		int[] rechts = new int[arr.length];
		int l = 0;
		int r = 0;
		for(int i = 0; i < arr.length; i++) // erster sortiervorgang aller
											// Zahlen die größer als Mitte sind
											// nach rechts
		{ // alle Zahlen die kleiner sind nach links
			if(arr[i] <= wert) {
				links[l] = arr[i];
				l++;
			} else {
				rechts[r] = arr[i];
				r++;
			}
		}
		int[] temp = new int[l];
		System.arraycopy(links, 0, temp, 0, temp.length);
		links = new int[temp.length];
		System.arraycopy(temp, 0, links, 0, links.length);
		temp = new int[r];
		System.arraycopy(rechts, 0, temp, 0, temp.length);
		rechts = new int[temp.length];
		System.arraycopy(temp, 0, rechts, 0, rechts.length);
		if(links.length > 1 && !isRepeatingNumber(links)) {
			links = quickSortAlgo(links);
		}
		if(rechts.length > 1 && !isRepeatingNumber(rechts)) {
			rechts = quickSortAlgo(rechts);
		}
		temp = new int[arr.length];
		System.arraycopy(links, 0, temp, 0, l);
		System.arraycopy(rechts, 0, temp, l, r);
		return temp; // bearbeitetes Array wird zurückgegeben
	}
	private static int getPivotElement(int[] array) {
		int count = 0;
		for(int i = 0; i < array.length; i++) {
			count += array[i];
		}
		return count / array.length;
	}
	private static boolean isRepeatingNumber(int[] array) {
		for(int i = 1; i < array.length; i++) {
			if(array[i] != array[i - 1]) {
				return false;
			}
		}
		return true;
	}
 

mamelinchen

Bekanntes Mitglied
Code:
public class QuickSortVerfahren {
	
	/******************************************************
	* Funktion zum Vertauschen von zwei Werten eines Arrays
	* Parameter:
	* @param- stapel: das Feld
	* @param- a: der erste Wert des Feldes stapel
	* @param- b:  der zweite Wert des Feldes stapel
	* @returnReturn: -
	* Effekt: die Werte des Stapels sind vertauscht
	*****************************************************/
	
	public static void tauscheWerte(int[]stapel,int a, int b){
		System.out.println(stapel[b]);
		int helper=stapel[a];                    // Hilfsvariable zum Vertauschen
		stapel[a]=stapel[b];
		stapel[b]=helper;
	}
	
	/******************************************************
	* Funktion zur Sortierung eines Feldes austeigend
	* Parameter:
	* @param- stapel: das zu sortierende Feld
	* @param- anfang: der Anfangswert des Feldes stapel
	* @param- ende:  der Endwert des Feldes stapel
	* Vorbedingung: R ist aufsteigend sortiert
	* @returnReturn: Sortiertes Feld aufsteigend,wenn Feld leer oder Größe 1,
	* dann wird das Feld stapel zurückgegeben
	* Effekt: -
	*****************************************************/
	

	public static void QuickSort(int[] stapel, int anfang, int ende) {
		if (ende > anfang) {
			int pivot = stapel[stapel.length-1];	//Pivotelement ist das Element am rechten Rand des Feldes
			int i = anfang;							//Rechter Index
			int j = ende-1;						//Linker Index

			while (i < j) {						//Wiederhole solange, wie die Indexe sich nicht überschneiden

				while (stapel[i] <= pivot && i < ende) {//Erhöhe Index i solange, bis der Wert an Index i kleiner ist, als das Pivotelement
					i++;
				}
				while (stapel[j] >= pivot && j> anfang) {			//Verringere Index j solange, bis der Wert an Index j grösser ist, als das Pivotelement
					j--;
				}
				if(i < j){
					tauscheWerte(stapel, i, j);     //Tausche die Werte, auf die i und j zeigen
					i++;			//Erhöhe Index i, um nächsten Wert zu prüfen
					j--;			//Verringere Index j, um nächsten Wert zu prüfen
				}
			}
			if (stapel[i] > pivot) {   		//Wenn Wert i in Array größer ist,als das Pivotelement,setze Pivot an endgültige Stelle
				tauscheWerte(stapel, i, pivot);
			}
			QuickSort(stapel, anfang, i+1);	//Anwendung von Quicksort auf dem rechten Abschnitt
			QuickSort(stapel, i -1, ende);	//Anwendung von Quicksort auf dem linken Abschnitt
		}
	}

	public static void main(String[] args) {
		int[] kleinarray = FileIntArray.FileToIntArray("../ALG1/src/a01/Rand20_1");
		QuickSort(kleinarray, 0, kleinarray.length);
//		for (int i = 0; i < kleinarray.length; i++) {
//			System.out.println(kleinarray[i] + "");
//		}
	}
}


An einer Stelle bleibt er hängen und vertauscht die Werte hin und her.
Die letzten Werte, die das Kriterium erfüllen..

Aber Wo Wieso Warum!?
 
S

SlaterB

Gast
alle anderen sollen nun also tage-, wenn nicht wochenlang tausende Test-Fälle zusammenbasteln,
bis sie eine Konstellation finden, bei der es zu einem komplizierten Fehler kommt

ODER

du postest genau, welche Eingabe verwendest,
(total simpel: int[] kleinarray = new int[] {4, 5, 1, 3}; wozu die Datei in der Testphase?)
+ wann es wo zu welchem Fehler kommt
 

mamelinchen

Bekanntes Mitglied
int[] {16, 4, 13, 19, 9, 10, 5,5,2,7,14,18,16,19,6,15,2,10,11,13}

13 ist mein Pivot.

Der Fehler liegt hier:

{16, 4, 13, 19, 9, 10, 5,5,2,7,14,18,16,19,6,15,2,10,11,13}

Er vertauscht die beiden immer wieder, obwohl ich den Zeiger von beiden erhöhe und die while Schleife oben eigentlich nicht fassen sollte, da dann i>j!!

Aber er machts trotzdem.
 
S

SlaterB

Gast
ich hab jetzt bisschen angefangen zu debuggen, aber da kommen eher immer mehr Fehler als dass was zu deinem zu finden wäre,
Beispiel:
> tauscheWerte(stapel, i, pivot);
pivot ist der WERT, übergeben werden muss aber der INDEX im Array

--------

> while (stapel <= pivot && i < ende) {
> i++;
> }

wenn das pivot der kleinste Wert ist, wird i bis zum Maximum erhöht und es gibt eine ArrayIndexOutOfBoundException,
die Abfrage 'i < ende' muss doch VOR dem Array-Zugriff stattfinden

--------

wieso ist das Pivot-Element immer das Ende des Arrays?
wenn man nur die erste Hälfte sortiert, kann man doch nur daraus etwas wählen, nicht auf fremde Teile des Arrays zugreifen

usw.
von den laufenden Exceptions wird man drauf hingewiesen, mit System.out.println alles zu debuggen,
Tipp: fange mit kurzen Arrays wie {16, 4, 13, 1} an
 

mamelinchen

Bekanntes Mitglied
wenn das pivot der kleinste Wert ist, wird i bis zum Maximum erhöht und es gibt eine ArrayIndexOutOfBoundException,
die Abfrage 'i < ende' muss doch VOR dem Array-Zugriff stattfinden

aber mit && drücke ich doch aus ,das beide Bedingungen erfüllt sein müssen?
i<ende UND stapel <= pivot,oder?
 
S

SlaterB

Gast
Reihenfolge ist wichtig, erst auf Grenze prüfen, damit der zweite Test nicht ausgeführt werden muss,

erst der Array-Zugriff führt dagegen zur Exception

vergleiche mit:
Abzug drücken && Pistole entladen
vs
Pistole entladen && Abzug drücken
 

mamelinchen

Bekanntes Mitglied
Ahhhhh verstehe...

Hab ich gemacht.Auch das mit dem pivot und debugge grade.

Er führt jetzt den rekursiven Quicksort tausendmal aus.(habs net gezählt)

Setzte die Grenze zwar mit
QuickSort(stapel, anfang, i), da ja dann i als pivot -1 definiert wird,also eine Stelle vor dem vorherigen Pivot.
Mein Fehler ist jetzt, das er den linken Zähler dauernd erhöht , da die Werte ALLE kleiner sind als das neue Pivot!

Was mach ich n nu?
 
S

SlaterB

Gast
schau nach, was der Original-Algorithmus dazu sagt, wahrscheinlich sollte ja wenigstens ein Element abgetrennt werden, und sei es der Pivot,
dann muss die Restliste (Länge-1) sortiert werden, mit neuem Pivot, wie ich schon angemerkt hatte,

im schlimmsten Fall passiert das n-Mal hintereinander, aber so das ist eben bei Quicksort, Worstcase ist eine bereits sortierte Liste,
spätestens nach n Runden ist man dennoch fertig, Endlosschleife ausgeschlossen, falls korrekt umgesetzt
 

mamelinchen

Bekanntes Mitglied
Code:
package a01;

public class QuickSortVerfahren {
	
	/******************************************************
	* Funktion zum Vertauschen von zwei Werten eines Arrays
	* Parameter:
	* @param- stapel: das Feld
	* @param- a: der erste Wert des Feldes stapel
	* @param- b:  der zweite Wert des Feldes stapel
	* @returnReturn: -
	* Effekt: die Werte des Stapels sind vertauscht
	*****************************************************/
	
	public static void tauscheWerte(int[]stapel,int a, int b){
		System.out.println(stapel[a]);
		System.out.println(stapel[b]);
		int helper=stapel[a];                    // Hilfsvariable zum Vertauschen
		stapel[a]=stapel[b];
		stapel[b]=helper;
	}
	
	/******************************************************
	* Funktion zur Sortierung eines Feldes austeigend
	* Parameter:
	* @param- stapel: das zu sortierende Feld
	* @param- anfang: der Anfangswert des Feldes stapel
	* @param- ende:  der Endwert des Feldes stapel
	* Vorbedingung: R ist aufsteigend sortiert
	* @returnReturn: Sortiertes Feld aufsteigend,wenn Feld leer oder Größe 1,
	* dann wird das Feld stapel zurückgegeben
	* Effekt: -
	*****************************************************/
	

	public static void QuickSort(int[] stapel, int anfang, int ende) {
		if (ende > anfang) {
			int pivot = stapel[ende-1];	//Pivotelement ist das Element am rechten Rand des Feldes
			int i = anfang;							//Rechter Index
			int j = ende-1;						//Linker Index

			while (i < j) {						//Wiederhole solange, wie die Indexe sich nicht überschneiden

				while ( i < ende && stapel[i] <= pivot ) {//Erhöhe Index i solange, bis der Wert an Index i kleiner ist, als das Pivotelement
					i++;
				}
				while (j> anfang && stapel[j] >= pivot) {//Verringere Index j solange, bis der Wert an Index j grösser ist, als das Pivotelement
					j--;
				}
				if(i < j){
					tauscheWerte(stapel, i, j);     //Tausche die Werte, auf die i und j zeigen
				}
			}
			if (stapel[i] > pivot) {  
				tauscheWerte(stapel, i, ende-1);//Wenn Wert i in Array größer ist,als das Pivotelement,setze Pivot an endgültige Stelle
			}

			QuickSort(stapel, anfang, i);	//Anwendung von Quicksort auf dem rechten Abschnitt
			QuickSort(stapel, i+1 , ende);	//Anwendung von Quicksort auf dem linken Abschnitt
		}
	}

	public static void main(String[] args) {
		int[] kleinarray = FileIntArray.FileToIntArray("../ALG1/src/a01/Rand20_1");
		QuickSort(kleinarray, 0, kleinarray.length);
//		for (int i = 0; i < kleinarray.length; i++) {
//			System.out.println(kleinarray[i] + "");
//		}
	}
}

Sortier das erste ma perfekt, danach vertauscht er das Pivot {6}
(alle Werte grösser und kleiner)
und tauscht es aber nochmals mit einem Wert vorher im Arrray, der kleiner ist.{5}

WIESO!!!

Das kann doch net sein!

Werte von Anfang an:
OriginalArray
16
4
13
19
9
10
5
5
2
7
14
18
16
19
6
15
2
10
11
13
:____________

16}Zu tauschende Elemente
11}
19
10
14
2
18
6
16
13
_______
linkes Teilarray
11
2
13
2
10
5
9
5
10
6Pivottausch
6???????
5???????

Ick versteh dit nich.
 
S

SlaterB

Gast
schlechtes Log, das kann man so schön machen:
Java:
package testmain;

import java.io.Serializable;

public class Test implements Serializable {

	public static void main(String argv[]) throws Exception {
		int[] kleinarray = new int[] { 16, 4, 13, 19, 9, 10, 5, 5, 2, 7, 14,
				18, 16, 19, 6, 15, 2, 10, 11, 13 };
		QuickSortVerfahren.QuickSort(kleinarray, 0, kleinarray.length);
		// for (int i = 0; i < kleinarray.length; i++) {
		// System.out.println(kleinarray[i] + "");
		// }

	}
}

class QuickSortVerfahren {

	/***************************************************************************
	 * Funktion zum Vertauschen von zwei Werten eines Arrays Parameter:
	 * 
	 * @param- stapel: das Feld
	 * @param- a: der erste Wert des Feldes stapel
	 * @param- b: der zweite Wert des Feldes stapel
	 * @returnReturn: - Effekt: die Werte des Stapels sind vertauscht
	 **************************************************************************/

	public static void tauscheWerte(int[] stapel, int a, int b) {
		System.out.println("tausche " + stapel[a] + ", " + stapel[b]
				+ " (Indexe " + a + ", " + b + ")");
		int helper = stapel[a]; // Hilfsvariable zum Vertauschen
		stapel[a] = stapel[b];
		stapel[b] = helper;
	}

	/***************************************************************************
	 * Funktion zur Sortierung eines Feldes austeigend Parameter:
	 * 
	 * @param- stapel: das zu sortierende Feld
	 * @param- anfang: der Anfangswert des Feldes stapel
	 * @param- ende: der Endwert des Feldes stapel Vorbedingung: R ist
	 *         aufsteigend sortiert
	 * @returnReturn: Sortiertes Feld aufsteigend,wenn Feld leer oder Größe 1,
	 *                dann wird das Feld stapel zurückgegeben Effekt: -
	 **************************************************************************/

	public static void QuickSort(int[] stapel, int anfang, int ende) {
		String info = "quicksort " + anfang + ", " + ende + ", Array: ";
		for (int i = anfang; i < ende; i++) {
			info += stapel[i] + ", ";
		}
		System.out.println(info);
		try {
			Thread.sleep(100);
		} catch (InterruptedException e) {
			e.printStackTrace();
		}
		if (ende > anfang) {
			int pivot = stapel[ende - 1]; // Pivotelement ist das Element am
			System.out.println("pivot: " + pivot);
			// rechten Rand des Feldes
			int i = anfang; // Rechter Index
			int j = ende - 1; // Linker Index

			while (i < j) { // Wiederhole solange, wie die Indexe sich nicht
				// überschneiden

				while (i < ende && stapel[i] <= pivot) {// Erhöhe Index i
					// solange, bis der Wert
					// an Index i kleiner
					// ist, als das
					// Pivotelement
					i++;
				}
				while (j > anfang && stapel[j] >= pivot) {// Verringere Index
					// j solange, bis
					// der Wert an Index
					// j grösser ist,
					// als das
					// Pivotelement
					j--;
				}
				if (i < j) {
					tauscheWerte(stapel, i, j); // Tausche die Werte, auf die i
					// und j zeigen
				}
			}
			if (stapel[i] > pivot) {
				tauscheWerte(stapel, i, ende - 1);// Wenn Wert i in Array
				// größer ist,als das
				// Pivotelement,setze Pivot
				// an endgültige Stelle
			}

			QuickSort(stapel, anfang, i); // Anwendung von Quicksort auf dem
			// rechten Abschnitt
			QuickSort(stapel, i + 1, ende); // Anwendung von Quicksort auf dem
			// linken Abschnitt
		}
	}
}

Ausgabe:
Code:
quicksort 0, 20, Array: 16, 4, 13, 19, 9, 10, 5, 5, 2, 7, 14, 18, 16, 19, 6, 15, 2, 10, 11, 13, 
pivot: 13
tausche 16, 11 (Indexe 0, 18)
tausche 19, 10 (Indexe 3, 17)
tausche 14, 2 (Indexe 10, 16)
tausche 18, 6 (Indexe 11, 14)
tausche 16, 13 (Indexe 12, 19)
quicksort 0, 12, Array: 11, 4, 13, 10, 9, 10, 5, 5, 2, 7, 2, 6, 
pivot: 6
tausche 11, 2 (Indexe 0, 10)
tausche 13, 2 (Indexe 2, 8)
tausche 10, 5 (Indexe 3, 7)
tausche 9, 5 (Indexe 4, 6)
tausche 10, 6 (Indexe 5, 11)
quicksort 0, 5, Array: 2, 4, 2, 5, 5, 
pivot: 5
tausche 6, 5 (Indexe 5, 4)
quicksort 0, 5, Array: 2, 4, 2, 5, 6, 
pivot: 6
quicksort 0, 5, Array: 2, 4, 2, 5, 6, 
pivot: 6
quicksort 0, 5, Array: 2, 4, 2, 5, 6, 
pivot: 6
.........
was stört dich am letzten Tausch von 6 und 5, finde ich logisch,
danach wird allerdings für alle Zeit bzw. bis zu einer StackOverflowException
quicksort 0, 5 aufgerufen,

wie ich gesagt habe: wenn das Pivot ein Randelement ist, dann muss man doch wenigstens ein Element abziehen und nur noch eine kleinere Menge sortieren,
überlege, ob du das bisher implementiert hast, wenn nicht, dann tue es, wenn doch, dann schaue dir die Schleife genau an,
wann wo warum i und j erhöht oder gesenkt werden
 
S

SlaterB

Gast
edit: nicht so sinnvoll was hier stand

nochmal neu:
wenn ich deinen Code mit
Quicksort ? Wikipedia
vergleiche, dann sehe ich dort
> pivot := daten[rechts]
> wiederhole solange daten ≤ pivot und i < rechts

während du
> pivot = stapel[ende - 1];
> while (i < ende && stapel <= pivot)
hast

das passt nicht zusammen, daher wahrscheinlich auch die ArrayOutOfBoundException und die umzudrehende Reihenfolge der while-Bedingungen,
der ende-Index muss wohl generell um 1 kleiner
 
Zuletzt bearbeitet von einem Moderator:

mamelinchen

Bekanntes Mitglied
Weil die 6 vor die 5 kommt, und das ist nicht sortiert....

Tolle Ausgabe;)

Reihenfolge ist wichtig, erst auf Grenze prüfen, damit der zweite Test nicht ausgeführt werden muss,

erst der Array-Zugriff führt dagegen zur Exception

vergleiche mit:
Abzug drücken && Pistole entladen
vs
Pistole entladen && Abzug drücken

Ich dachte?


Das von Wicki hat ich auch schon, geht nicht.
 
S

SlaterB

Gast
ich verstehe in deiner Antwort jetzt nicht allzu viel,
hier aber noch eine sortierende Version wie im Wiki, mit einfachen Änderungen zu -1, die ich schon angesprochen hatte
Java:
public class Test implements Serializable {

	public static void main(String argv[]) throws Exception {
		int[] kleinarray = new int[] { 16, 4, 13, 19, 9, 10, 5, 5, 2, 7, 14,
				18, 16, 19, 6, 15, 2, 10, 11, 13 };
		QuickSortVerfahren.QuickSort(kleinarray, 0, kleinarray.length - 1);
		System.out.println("sortiert: " + Arrays.toString(kleinarray));

	}
}

class QuickSortVerfahren {

	/***************************************************************************
	 * Funktion zum Vertauschen von zwei Werten eines Arrays Parameter:
	 * 
	 * @param- stapel: das Feld
	 * @param- a: der erste Wert des Feldes stapel
	 * @param- b: der zweite Wert des Feldes stapel
	 * @returnReturn: - Effekt: die Werte des Stapels sind vertauscht
	 **************************************************************************/

	public static void tauscheWerte(int[] stapel, int a, int b) {
		System.out.println("tausche " + stapel[a] + ", " + stapel[b]
				+ " (Indexe " + a + ", " + b + ")");
		int helper = stapel[a]; // Hilfsvariable zum Vertauschen
		stapel[a] = stapel[b];
		stapel[b] = helper;
	}

	/***************************************************************************
	 * Funktion zur Sortierung eines Feldes austeigend Parameter:
	 * 
	 * @param- stapel: das zu sortierende Feld
	 * @param- anfang: der Anfangswert des Feldes stapel
	 * @param- ende: der Endwert des Feldes stapel Vorbedingung: R ist
	 *         aufsteigend sortiert
	 * @returnReturn: Sortiertes Feld aufsteigend,wenn Feld leer oder Größe 1,
	 *                dann wird das Feld stapel zurückgegeben Effekt: -
	 **************************************************************************/

	public static void QuickSort(int[] stapel, int anfang, int ende) {
		String info = "quicksort " + anfang + ", " + ende + ", Array: ";
		for (int i = anfang; i <= ende; i++) {
			info += stapel[i] + ", ";
		}
		System.out.println(info);
		try {
			Thread.sleep(100);
		} catch (InterruptedException e) {
			e.printStackTrace();
		}
		if (ende > anfang) {
			int pivot = stapel[ende]; // Pivotelement ist das Element am
			System.out.println("pivot: " + pivot);
			// rechten Rand des Feldes
			int i = anfang; // Rechter Index
			int j = ende - 1; // Linker Index

			while (i < j) { // Wiederhole solange, wie die Indexe sich nicht
				// überschneiden

				while (i < ende && stapel[i] <= pivot) {// Erhöhe Index i
					// solange, bis der Wert
					// an Index i kleiner
					// ist, als das
					// Pivotelement
					i++;
				}
				while (j > anfang && stapel[j] >= pivot) {// Verringere Index
					// j solange, bis
					// der Wert an Index
					// j grösser ist,
					// als das
					// Pivotelement
					j--;
				}
				if (i < j) {
					tauscheWerte(stapel, i, j); // Tausche die Werte, auf die i
					// und j zeigen
				}
			}
			if (stapel[i] > pivot) {
				tauscheWerte(stapel, i, ende);// Wenn Wert i in Array
				// größer ist,als das
				// Pivotelement,setze Pivot
				// an endgültige Stelle
			}

			QuickSort(stapel, anfang, i - 1); // Anwendung von Quicksort auf
												// dem
			// rechten Abschnitt
			QuickSort(stapel, i + 1, ende); // Anwendung von Quicksort auf dem
			// linken Abschnitt
		}
	}
}
für deine 10.000-Datei die Log-Ausgaben und vor allem das Thread.sleep(100) besser ausbauen ;)
 

mamelinchen

Bekanntes Mitglied
Ahhhhhhhhhhhhhhhhh klappt alles wunderbar!!


Und 100000 geht auch!


Was hast du gemacht?!?!?!

SIEHT NCIH ANDERS AUS ALS MEINS,

oder doch?

DANKEEEEE DANKE:D
 
Status
Nicht offen für weitere Antworten.
Ähnliche Java Themen
  Titel Forum Antworten Datum
M Wo ist der Fehler in meinem Programm? Java Basics - Anfänger-Themen 12
B Wo ist der Fehler in meinem Script Java Basics - Anfänger-Themen 4
F Kann mir jemand bei dem Fehler helfen? Java Basics - Anfänger-Themen 6
Juelin jedit Fehler beim starten Java Basics - Anfänger-Themen 2
I Frage Thymeleaf -> Fehler ignorieren und mit "" ersetzen? Java Basics - Anfänger-Themen 15
E Matrizenmultiplikation Fehler Java Basics - Anfänger-Themen 0
Z Fehler Zeiterfassungsprogramm Anzeige Java Basics - Anfänger-Themen 3
C SwingWorker mit Fehler Java Basics - Anfänger-Themen 2
monsterherz Fehler Semikolon fehlt - ich weiss aber nicht wo da noch eines hin sollte... Java Basics - Anfänger-Themen 21
G Compiler-Fehler Fehler in Zeile 1 beheben, wie? Java Basics - Anfänger-Themen 9
W Fehler in der Datei pom.xml Java Basics - Anfänger-Themen 19
marcelnedza Finde meinen Fehler in einer Methode nicht, Java Karol Java Basics - Anfänger-Themen 15
monsterherz einfache Methode mit Fehler den ich nicht finde Java Basics - Anfänger-Themen 21
monsterherz if / else if mit Fehler den ich leider nicht finde Java Basics - Anfänger-Themen 11
N Interpreter-Fehler Compiler zeigt keine Fehler an, aber das Programm läuft nicht (BlueJ) Java Basics - Anfänger-Themen 2
ohneInformatik; Dynamische Zinsen. Wo liegt der Fehler? Java Basics - Anfänger-Themen 4
Fiedelbambu deriveFont Fehler wer kann Helfen? Java Basics - Anfänger-Themen 4
I Ical4j / Kalender einlesen von URL - Fehler: "Unparseable date" Java Basics - Anfänger-Themen 16
Lion.King Fehler in double und int Java Basics - Anfänger-Themen 7
H BlueJ: was genau ist hier der Fehler? Java Basics - Anfänger-Themen 14
berserkerdq2 Habe ein Spiel entwickelt, dass immer in der 4 Runde einen cast-Fehler erhält Java Basics - Anfänger-Themen 3
D Datentypen LocalDate.parse() ergibt Fehler Java Basics - Anfänger-Themen 5
stormyark Fehler beim überschreiben einer Variable Java Basics - Anfänger-Themen 1
T String Array Fehler beim Index Java Basics - Anfänger-Themen 3
N Fehler "Cannot instantiate the type" Java Basics - Anfänger-Themen 3
L Ich weis nicht was der Fehler ist! Java Basics - Anfänger-Themen 14
L30nS JNI Fehler, JRE und JDK Java Basics - Anfänger-Themen 8
E Executable jar file fehler Java Basics - Anfänger-Themen 9
S Fehler beim Programm Java Basics - Anfänger-Themen 2
U Warum kriege ich hier eine nullpointer exception, sehe den Fehler nicht (swing) Java Basics - Anfänger-Themen 1
J Syntax-Fehler? Java Basics - Anfänger-Themen 2
Jose05 Fehler im Programm feststellen Java Basics - Anfänger-Themen 2
S Methoden 2 non-static Methoden, trotzdem Fehler "non static method can not be referenced from a static context" Java Basics - Anfänger-Themen 9
G Taschenrechner ergibt Fehler in if-Abfrage Java Basics - Anfänger-Themen 6
I Fehler bei for-Schleife Java Basics - Anfänger-Themen 6
lol5443 Tic Tac Toe Fehler Java Basics - Anfänger-Themen 5
K Fehler bei der Implementierung Java Basics - Anfänger-Themen 6
N Fehler im Code (Aufgabe für Anfänger) Java Basics - Anfänger-Themen 11
W Verschachtelte If-else --> finde meinen Fehler nicht Java Basics - Anfänger-Themen 30
J Fehler bei array aus anderer Klasse Java Basics - Anfänger-Themen 3
H Fehler bei integer Division Java Basics - Anfänger-Themen 28
C Fehler beim erstellen eines Objektes Java Basics - Anfänger-Themen 3
N Was bedeutet dieser Fehler Java Basics - Anfänger-Themen 2
fuerteb Compiler-Fehler Methode wird nicht bzw. als Fehler erkannt Java Basics - Anfänger-Themen 4
Lion.King Fehler Java Basics - Anfänger-Themen 5
AlexG. Nullpointer exeption Fehler Java Basics - Anfänger-Themen 0
C Fehler im Code Java Basics - Anfänger-Themen 10
J Anfänger, Fehler; "Der Hund liegt begraben" Java Basics - Anfänger-Themen 3
Aqtox Hallo ich muss für die Schule ein Wuerfell Duell erstellen jedoch habe ich ein fehler Java Basics - Anfänger-Themen 4
V Wer findet den Fehler :) Java Basics - Anfänger-Themen 12
B ArrayIndexOutOfBoundsException, ich finde den Fehler nicht? Java Basics - Anfänger-Themen 10
A Compiler Fehler - not a statement Java Basics - Anfänger-Themen 2
Arita welche Fehler gibt es noch? wie kann ich es noch vervollständigen Java Basics - Anfänger-Themen 15
S Fehler bei Code mit SubStrings für mich nicht auffindbar. Java Basics - Anfänger-Themen 4
S Kriege Fehler "Exception in thread" beim Benutzen von SubStrings. Java Basics - Anfänger-Themen 2
H Logik Fehler erkennen Java Basics - Anfänger-Themen 21
T Fehler in Caesar-Chiffre Java Basics - Anfänger-Themen 7
R Fehlermeldung aber WO liegt der Fehler? Java Basics - Anfänger-Themen 7
B Nicht reproduzierbarer Fehler bei Kompilierung - Shortcut "Bereinigung" Compiler ? Java Basics - Anfänger-Themen 4
Nerdinfekt BMI Rechner, fehler beim Zurückgeben des Strings? Java Basics - Anfänger-Themen 2
pumpgun99 Fehler Meldung "else without if" Java Basics - Anfänger-Themen 3
P Was bedeutet dieser Fehler? Java Basics - Anfänger-Themen 31
KogoroMori21 Java Datum Differenz (kleiner Fehler) Java Basics - Anfänger-Themen 10
N java.util.InputMismatchException Fehler Java Scanner Java Basics - Anfänger-Themen 5
H Fehler: NullPointerException und ich weiß net warum Java Basics - Anfänger-Themen 4
R Ich sehe meinen fehler nicht Java Basics - Anfänger-Themen 8
Johannes_ece Fehler: Application Terminated (TypeError): var$0.$moveToolTo is not a function Java Basics - Anfänger-Themen 4
GermanPie Fehler in Putty (kein Hauptmanifestattribut, in jar) Java Basics - Anfänger-Themen 4
M Scannen von *.txt - Dateien; wo sind der oder die Fehler? Java Basics - Anfänger-Themen 4
P Methoden aufrufen - Fehler Java Basics - Anfänger-Themen 20
JavaClap "Bruchrechner" liefert Fehler/keine Ausgabe bei Addition und Subtraktion Java Basics - Anfänger-Themen 0
B if Clause Fehler Java Basics - Anfänger-Themen 2
G Fibonacci Zahlenreihe Fehler Java Basics - Anfänger-Themen 4
A Fehler beim Ausführen einer class Datei Java Basics - Anfänger-Themen 6
B Fehler, aber ich weiß nicht warum Java Basics - Anfänger-Themen 3
C system cannot be resolved Fehler in Eclipse Java Basics - Anfänger-Themen 18
J Fehler im Code, aber ich weiß nicht wieso! Java Basics - Anfänger-Themen 6
M Compiler-Fehler Fehler beim Ausführen des Codes Java Basics - Anfänger-Themen 25
M While-Schleifen-Fehler Java Basics - Anfänger-Themen 4
N Fehler bei JUnit Test Java Basics - Anfänger-Themen 5
C Projekte in 2 versch. Arbeitsbereichen: auf ein Projekt verweisen (ohne Fehler zu bekommen) Java Basics - Anfänger-Themen 8
R Java SQL Fehler! Java Basics - Anfänger-Themen 4
L non-static Fehler Java Basics - Anfänger-Themen 16
C Fehler beim Speichern (Build projekt) Java Basics - Anfänger-Themen 42
L Methoden Wie Löse ich ext Methoden Aufruf Fehler? Java Basics - Anfänger-Themen 3
F Methoden Bitte Helft mir meinen Fehler zu finden. Möchte in diesem Bankenprogramm durch die Konsoleneingabe auswählen welches Konto reduziert und welches erhö Java Basics - Anfänger-Themen 17
C Fehler bei der Compilierung Java Basics - Anfänger-Themen 1
T Mein Programm hat Fehler Java Basics - Anfänger-Themen 4
S Warum dieser Fehler? Java Basics - Anfänger-Themen 1
B Fehler bei Ausführung Java Basics - Anfänger-Themen 5
Kirby.exe Fehler beim Ausgeben Java Basics - Anfänger-Themen 2
X java.lang.NullPointerException fehler ? Java Basics - Anfänger-Themen 1
L Wo ist der Fehler? Java Basics - Anfänger-Themen 87
J Fehler in Programm: Index -1 out of bounds for length 0 Java Basics - Anfänger-Themen 5
M JOptionPane Fehler bei "Abbrechen" des Fensters Java Basics - Anfänger-Themen 10
N Fehler bei string Attribut! Java Basics - Anfänger-Themen 18
W Wo liegt der Fehler? Java Basics - Anfänger-Themen 8
G Palindromtest mit Angabe WO der Fehler ist Java Basics - Anfänger-Themen 2
J Wo ist der Fehler im Programmcode? Java Basics - Anfänger-Themen 7
J Fehler den ich nicht kapiere Java Basics - Anfänger-Themen 9

Ähnliche Java Themen

Neue Themen


Oben