package TestTwo.demo4;
import java.util.Arrays;
public class QuickSort {
public static void main(String[] args) {
int[] array = new int[]{2, 3, 4, 5, 6, 3, 7, 7, 5, 3, 2};
quickSort(array, 0, array.length - 1);
System.out.println(Arrays.toString(array));
}
public static void quickSort(int[] array, int start, int end) {
if (start < end) {
//记录需要排序的下标
int low = start;
int high = end;
//把数组中第零个数字作为标准数
int standard = array[start];
//循环找比标准数大的数和比标准数小的数
while (low < high) {
//右边的数字比标准数大
while (low < high && standard <= array[high]) {
high--;
}
array[low] = array[high];
//如果左边的数比标准数小
while (low < high && standard >= array[high]) {
low++;
}
array[high] = array[low];
}
//把标准数赋值给低所在位置的元素
array[low] = standard;
//处理所有的小的数字
quickSort(array, start, low);
//处理所有的大的数字
quickSort(array, low + 1, end);
}
}
}
快速排序
最新推荐文章于 2023-12-01 23:14:38 发布