import java.util.Random;
public class QuickSort {
public static int partition(int[] arr, int low, int high) {
int pivot = arr[low];
while (low < high) {
while (low < high && arr[high] >= pivot) {
--high;
}
arr[low] = arr[high];
while (low < high && arr[low] <= pivot) {
++low;
}
arr[high] = arr[low];
}
arr[low] = pivot;
return low;
}
public static void quicksort(int[] arr, int low, int high) {
if (low < high) {
int pivotpos = partition(arr, low, high);
quicksort(arr, low, pivotpos - 1);
quicksort(arr, pivotpos + 1, high);
}
}
public static void main(String[] args) {
Random random = new Random();
int[] A=new int[10];
for (int i = 0; i < 10; i++) {
A[i] = random.nextInt(10);
}
for (int i = 0; i < A.length; i++) {
System.out.print(A[i]+" ");
}
System.out.println();
quicksort(A, 0, A.length-1);
for (int i = 0; i < A.length; i++) {
System.out.print(A[i]+" ");
}
}
}
Java 快排
最新推荐文章于 2023-09-27 12:57:39 发布