import java.util.Arrays;
/**
* @author lixin
* @date 2019/3/15 - 21:14
*/
public class QuickSort {
public static void main(String[] args) {
int[] arr = new int[]{1, 3, 4, 5, 2, 7, 6, 4, 5};
quick(arr, 0, arr.length - 1);
System.out.println(Arrays.toString(arr));
}
public static void quick(int[] arr, int start, int end) {
if (start < end) {
//把数组中的第0个数字作为标准数
int stard = arr[start];
//记录需要排序的下标
int low = start;
int high = end;
//循环找比标准数大的数和比标准数小的数
while (low < high) {
//右边的数字比标准数大
while (low < high && stard <= arr[high]) {
high--;
}
//使用右边的数字替换左边的数
arr[low] = arr[high];
//如果左边的数字比标准数小
while (low < high && arr[low] <= stard) {
low++;
}
arr[high] = arr[low];
}
//把标准数赋贵低所在的位置的元素
arr[low] = stard;
//处理所有的小的数字
quick(arr, start, low);
//处理所有的大的数字
quick(arr, low + 1, end);
}
}
}
数据结构与算法基础-快速排序(Java)
最新推荐文章于 2024-01-28 22:49:25 发布