Java程序实现快速排序算法
要理解这个示例,你应该具备以下 Java 编程主题的知识:
Java 中的快速排序
快速排序算法基于分而治之的方法,通过选择一个基准元素将数组划分为子数组。
在划分数组时,应该这样定位基准元素:使得小于基准的元素放在左边,大于基准的元素放在右边。
对左右子数组重复相同的过程。最后,将排序好的元素组合成一 个排序数组。
要了解更多,请访问 快速排序算法。
示例:Java 程序实现快速排序算法
import java.util.Arrays;
class Quicksort {
// 查找分区位置的方法
static int partition(int array[], int low, int high) {
// 选择最右边的元素作为基准
int pivot = array[high];
// 指向大于基准的元素的指针
int i = (low - 1);
// 遍历所有元素
// 将每个元素与基准进行比较
for (int j = low; j < high; j++) {
if (array[j] <= pivot) {
// 找到比基准小的元素
// 与指针 i 指向的较大元素交换
i++;
// 交换 i 和 j 的元素
int temp = array[i];
array[i] = array[j];
array[j] = temp;
}
}
// 将基准元素与指针 i 指向的较大元素交换
int temp = array[i + 1];
array[i + 1] = array[high];
array[high] = temp;
// 返回分区完成的位置
return (i + 1);
}
static void quickSort(int array[], int low, int high) {
if (low < high) {
// 找到基准元素,使得
// 小于基准的在左边
// 大于基准的在右边
int pi = partition(array, low, high);
// 对基准左边递归调用
quickSort(array, low, pi - 1);
// 对基准右边递归调用
quickSort(array, pi + 1, high);
}
}
}
// 主类
class Main {
public static void main(String args[]) {
int[] data = { 8, 7, 2, 1, 0, 9, 6 };
System.out.println("未排序的数组");
System.out.println(Arrays.toString(data));
int size = data.length;
// 对数组 data 调用 quicksort()
Quicksort.quickSort(data, 0, size - 1);
System.out.println("按升序排序的数组 ");
System.out.println(Arrays.toString(data));
}
}
输出
未排序的数组
[8, 7, 2, 1, 0, 9, 6]
按升序排序的数组
[0, 1, 2, 6, 7, 8, 9]
这里,数组的元素按升序排序。如果我们想按降序排序元素,可以在 for
循环中更改代码为:
// 小于号改为大于号
if (array[j] >= pivot) {