用Java写一个快速排序算法
时间: 2024-05-15 12:16:17 浏览: 88
Java 快速排序算法
以下是Java实现的快速排序算法:
```
public class QuickSort {
public static void quickSort(int[] arr, int left, int right) {
if (left < right) {
int pivotIndex = partition(arr, left, right); // 找到基准点的位置
quickSort(arr, left, pivotIndex - 1); // 对左子数组进行快速排序
quickSort(arr, pivotIndex + 1, right); // 对右子数组进行快速排序
}
}
public static int partition(int[] arr, int left, int right) {
int pivot = arr[left]; // 将数组第一个元素作为基准点
int i = left, j = right;
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; // 将基准点移动到其最终的位置
return i;
}
public static void main(String[] args) {
int[] arr = {5, 2, 9, 4, 7, 6, 1, 3, 8};
quickSort(arr, 0, arr.length - 1);
for (int i : arr) {
System.out.print(i + " ");
}
}
}
```
快速排序的时间复杂度为O(nlogn),是一种高效的排序算法。
阅读全文