分治法实现快速排序java大到小
时间: 2023-10-18 16:02:41 浏览: 154
分治法是一种常用于排序算法中的思想,其中快速排序是基于分治法思想的一种排序算法。快速排序的实现可以使得数组从小到大有序,但是如果想要实现从大到小有序,只需要对快速排序的基本操作进行一些修改。
在快速排序中,我们通过选择一个元素作为基准值,将数组分为两部分,一部分小于等于基准值,另一部分大于基准值。然后分别对这两部分递归进行快速排序,直到数组完全有序。
为了实现从大到小的排序,我们可以对快速排序的基本操作进行一些修改。具体而言,我们需要将比较操作从小于等于改为大于等于,将交换操作从左右交换改为右左交换。这样的修改可以保证在每一次排序操作中,基准值右边的元素都比基准值大。
下面是快速排序从大到小的Java代码实现:
```
public class QuickSort {
public static void quickSort(int[] arr, int low, int high) {
if (low < high) {
int pivotIndex = partition(arr, low, high);
quickSort(arr, low, pivotIndex - 1);
quickSort(arr, pivotIndex + 1, high);
}
}
public static int partition(int[] arr, int low, int high) {
int pivot = arr[low];
int left = low + 1;
int right = high;
while (true) {
while (left <= right && arr[left] >= pivot) {
left++;
}
while (left <= right && arr[right] >= pivot) {
right--;
}
if (left > right) {
break;
}
swap(arr, left, right);
}
swap(arr, low, right);
return right;
}
public static void swap(int[] arr, int i, int j) {
int temp = arr[i];
arr[i] = arr[j];
arr[j] = temp;
}
public static void main(String[] args) {
int[] arr = {5, 4, 3, 2, 1};
quickSort(arr, 0, arr.length - 1);
System.out.println(Arrays.toString(arr));
}
}
```
以上代码通过将比较和交换操作进行了相应的修改,可以实现对数组从大到小的快速排序。运行结果为[5, 4, 3, 2, 1]。
阅读全文