Java折中排序代码加注释
时间: 2023-10-18 21:24:06 浏览: 52
下面是一个简单的 Java 折中排序代码,附有注释:
```java
public class QuickSort {
// 折中排序方法
public void quickSort(int[] arr, int left, int right) {
if (left < right) {
int partitionIndex = partition(arr, left, right); // 获取分区索引
quickSort(arr, left, partitionIndex - 1); // 对左边进行排序
quickSort(arr, partitionIndex + 1, right); // 对右边进行排序
}
}
// 分区方法
private int partition(int[] arr, int left, int right) {
int pivot = left; // 设定基准值(pivot)
int index = pivot + 1;
for (int i = index; i <= right; i++) {
if (arr[i] < arr[pivot]) {
swap(arr, i, index);
index++;
}
}
swap(arr, pivot, index - 1);
return index - 1;
}
// 交换方法
private 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, 2, 9, 3, 7, 6, 1, 8, 4};
QuickSort quickSort = new QuickSort();
quickSort.quickSort(arr, 0, arr.length - 1);
System.out.println(Arrays.toString(arr));
}
}
```
注释中解释了每个方法的作用,以及如何执行折中排序。同时,还提供了一个简单的测试方法,以便验证排序是否成功。