java的快速排序怎么写?
时间: 2023-03-05 16:51:25 浏览: 53
Java的快速排序可以通过以下代码实现:
```java
public static void quickSort(int[] arr, int left, int right) {
if (left < right) {
int pivot = partition(arr, left, right); // 获取基准点
quickSort(arr, left, pivot - 1); // 对左边的子数组进行快速排序
quickSort(arr, pivot + 1, right); // 对右边的子数组进行快速排序
}
}
private static int partition(int[] arr, int left, int right) {
int pivot = arr[left]; // 选择第一个元素作为基准点
while (left < right) {
while (left < right && arr[right] >= pivot) {
right--;
}
arr[left] = arr[right];
while (left < right && arr[left] <= pivot) {
left++;
}
arr[right] = arr[left];
}
arr[left] = pivot; // 将基准点放回数组
return left;
}
```
其中,`quickSort`方法是快速排序的入口,它使用递归方式对数组进行分割和排序。`partition`方法是获取基准点的过程,它使用双指针的方式对数组进行遍历和交换。具体来说,`partition`方法将数组分成两部分,左边部分的所有元素小于等于基准点,右边部分的所有元素大于等于基准点。最后,`partition`方法将基准点放回数组,并返回基准点的下标。