這是代碼。輸出是一個非常接近正確的排序數組,但有幾個元素無序。任何人都可以發現錯誤?快速排序:幾乎排序,但不完全。怎麼了?
我很確定swap和quicksort方法是正確的,但我在這裏發佈所有的方法以防萬一。
package quicksort;
import java.util.Random;
import java.util.Arrays;
public class QuickSort {
/**
* @param args the command line arguments
*/
private static int[] u;
public static void main(String[] args) {
u = makeArray(100);
System.out.println(Arrays.toString(u));
quicksort(0, u.length - 1);
System.out.println(Arrays.toString(u));
}
public static int[] makeArray(int n) {
int[] a = new int[n];
int j;
Random r = new Random();
for (int i = 0; i < n; i++) {
j = (r.nextInt(100) + 1);
a[i] = j;
}
return a;
}
public static int partition(int left, int right, int pivot) {
int p = pivot; // pivot
int lPt = left - 1;
int rPt = right + 1;
while (true) {
while ((lPt < right) && (u[++lPt] < p));
while ((rPt > left) && (u[--rPt] > p));
if (lPt >= rPt) {
break;
} else {
swap(lPt, rPt);
System.out.println("Swapping " + lPt + " " + rPt);
}
}
return lPt;
}
public static void swap (int a, int b) {
int temp = u[a];
u[a] = u[b];
u[b] = temp;
}
public static void quicksort(int l, int r) {
if (r - l <= 0) {
return;
} else {
int part = partition(l, r, u[l]);
quicksort (l, part - 1);
quicksort (part + 1, r);
}
}
}
已回答。非常感謝時間和清楚的解釋。有點尷尬,我傳遞的是樞軸值而不是原始代碼中的位置。 – ACPrice 2013-05-03 13:05:00