java编写一个快速排序
时间: 2023-10-17 21:08:11 浏览: 77
java中的快速排序
算法的代码实现是什么?
下面是Java编写的快速排序算法的代码实现:
```
public class QuickSort {
public static void quickSort(int[] arr, int low, int high) {
if (low < high) {
int index = partition(arr, low, high);
quickSort(arr, low, index - 1);
quickSort(arr, index + 1, high);
}
}
private static int partition(int[] arr, int low, int high) {
int pivot = arr[high];
int i = low - 1;
for (int j = low; j < high; j++) {
if (arr[j] < pivot) {
i++;
int temp = arr[i];
arr[i] = arr[j];
arr[j] = temp;
}
}
int temp = arr[i + 1];
arr[i + 1] = arr[high];
arr[high] = temp;
return i + 1;
}
public static void main(String args[]) {
int[] arr = { 10, 7, 8, 9, 1, 5 };
int n = arr.length;
quickSort(arr, 0, n - 1);
for (int i = 0; i < n; i++) {
System.out.print(arr[i] + " ");
}
}
}
```
在这个代码中,quickSort方法将数组从low到high排序。首先,该方法调用partition方法选择一个元素作为枢轴元素,并对数组中的元素进行分区,使得小于枢轴元素的元素在枢轴元素的左侧,大于枢轴元素的元素在枢轴元素的右侧。接下来,该方法调用自身来对枢轴元素的左侧和右侧进行排序。partition方法使用i和j索引和pivot变量来在每次迭代中执行分区操作。在数组中,i表示小于(或等于)pivot的元素的最后一个元素的索引,j表示当前正在检查的元素的索引。如果当前元素小于枢轴元素,则交换i+1位置和j位置的元素。一旦完成循环,i+1位置的元素将作为新的枢轴元素,用于递归地排序左右两个分区。
阅读全文