Java 快速排序
时间: 2023-06-21 17:08:12 浏览: 80
快速排序是一种常用的排序算法,它的时间复杂度为O(nlogn)。下面是Java实现快速排序的代码:
```java
public class QuickSort {
public static void quickSort(int[] arr, int left, int right) {
if (left < right) {
int i = left, j = right, pivot = arr[left];
while (i < j) {
while (i < j && arr[j] >= pivot)
j--;
if (i < j)
arr[i++] = arr[j];
while (i < j && arr[i] < pivot)
i++;
if (i < j)
arr[j--] = arr[i];
}
arr[i] = pivot;
quickSort(arr, left, i - 1);
quickSort(arr, i + 1, right);
}
}
public static void main(String[] args) {
int[] arr = { 3, 6, 4, 2, 11, 10, 5 };
quickSort(arr, 0, arr.length - 1);
for (int i = 0; i < arr.length; i++) {
System.out.print(arr[i] + " ");
}
}
}
```
在该代码中,`quickSort`方法是递归地对数组进行快速排序。首先,选择数组的第一个元素作为基准点,然后使用两个指针`i`和`j`分别从左右两侧向中间扫描,将大于基准点的元素移到右边,小于等于基准点的元素移到左边。这样,基准点就被放在了正确的位置上,并且左边的元素都小于它,右边的元素都大于它。然后,递归地对基准点左侧和右侧的子数组进行快速排序,直到数组有序。
阅读全文