Ich habe derzeit den folgenden Code für meine schnelle Sortierung. Wie Sie sehen können, produziert es nicht die korrekte Ausgabe. Jede Hilfe wird sehr geschätzt. Ich brauche den Pivot als erstes Element im Array. Wie Sie auch sehen können, messe ich die Zeit, die es braucht, um zu laufen, aber bitte ignorieren Sie das vorläufig.QuickSort nicht iterative Lösung sortieren
edit: um genau zu sein, es funktioniert korrekt, wenn ich eine Liste in absteigender Reihenfolge und aufsteigender Reihenfolge (bereits sortiert), aber wenn ich eine zufällige Liste versuchen, funktioniert es nicht.
Ausgang:
QuickSort:
Quick Sort Took 181023 nanoseconds
Quick Sort Took 0 milliseconds
Sorted Quick Sort: 25, 12, 17, 13, 20, 7, 5, 16, 11, 26, 24, 18, 9, 4, 21, 1, 23, 27, 15, 19, 28, 14, 8, 22, 6, 3, 2, 10, 29, 40, 37, 32, 44, 38, 35, 41, 39, 31, 42, 30, 43, 36, 34, 33, 45, 46, 47, 48, 49, 50,
Code:
class QuickSort {
public static int Partition(int[] numbers, int left, int right){
//selects the first item at position [0] as the pivot
//left is given 0 when the method is called
int pivot = numbers[left];
while (true)
{
while (numbers[left] < pivot)
left++;
while (numbers[right] > pivot)
right--;
if (left < right)
{
int temp = numbers[right];
numbers[right] = numbers[left];
numbers[left] = temp;
}
else
{
return right;
}
}
}
//method to check for special cases
public static void QuickSort_Check(int[] numbers, int left, int right)
{
//special case of 2 items to be sorted
if(right == 1){
if(numbers[0] >= numbers[1]){
System.out.print("This is a special case of 2 inputs: ");
System.out.print(numbers[1] + ", " + numbers[0]);
System.exit(0);
}
else {
System.out.print("This is a special case of 2 inputs: ");
System.out.print(numbers[0] + ", " + numbers[1]);
System.exit(0);
}
System.exit(0);
}
//special case of 1 item to be sorted
else if (right == 0){
System.out.print("This is a special case of 1 input: ");
System.out.print(numbers[0]);
System.exit(0);
}
else {
QuickSort_Iterative(numbers, left, right);
}
}
public static class QuickPosInfo
{
public int left;
public int right;
};
public static QuickPosInfo spot = new QuickPosInfo();
public static void QuickSort_Iterative(int[] numbers, int left, int right)
{
if(left >= right)
return; // Invalid index range
LinkedList<QuickPosInfo> list = new LinkedList< QuickPosInfo>();
spot.left = left;
spot.right = right;
list.add(spot);
while(true)
{
if(list.size() == 0)
break;
left = list.get(0).left;
right = list.get(0).right;
list.remove(0);
int pivot = Partition(numbers, left, right);
if(pivot > 1)
{
spot.left = left;
spot.right = pivot - 1;
list.add(spot);
}
if(pivot + 1 < right)
{
spot.left = pivot + 1;
spot.right = right;
list.add(spot);
}
}
}
}
Ich werde Ihren Code ausführen und sehen, ob ich etwas sehe. – sbowde4
@ sbowde4 um genau zu sein, funktioniert es richtig, wenn ich eine Liste in absteigender Reihenfolge und aufsteigender Reihenfolge (bereits sortiert) habe, aber wenn ich eine zufällige Liste versuche, funktioniert es nicht. – cfsprod
Ich verwende die Zufallsliste, die Sie zur Verfügung gestellt haben – sbowde4