排序算法——快速排序
1. 介绍
快速排序(Quicksort)是对冒泡排序的一种改进。基本思想是:通过一趟排序将要排序的数据分割成独立的两 部分,其中一部分的所有数据都比另外一部分的所有数据都要小,然后再按此方法对这两部分数据分别进行快速排 序,整个排序过程可以递归进行,以此达到整个数据变成有序序列
2. 快速排序法示意图
3. 复杂度
平均时间复杂度:O(NlogN)
最佳时间复杂度:O(NlogN)
最差时间复杂度:O(N^2)
空间复杂度:根据实现方式的不同而不同
4. 应用实例
要求: 对 [-9,78,0,23,-567,70] 进行从小到大的排序,要求使用快速排序法。
技巧:
一般先把最左边的数当作基准数,然后从右边开始检索比基准数小的,再从左边判断比基准数大的,再把两个数交换位置,小的放在左边,大的放在右边,当检索下标重合的时候,将重合位置上的数与基准数交换位置
package com.blog.blog_vlog.aspect;
import java.util.Arrays;
public class Ks {
public static void main(String[] args) {
int[] arr = {-9, 78, 0, 23, -567, 70, -1, 900, 4561};
quickSort(arr, 0, arr.length - 1);
System.out.println(Arrays.toString(arr));
}
public static void quickSort(int[] arr, int left, int right) {
if (left > right) {
return;
}
int base = arr[left]; //定义基准数
//定义变量 指向最左边
int i = left;
//定义变量 指向最右边
int j = right;
int temp = 0; //临时变量
while (i!=j){
//先从右边边开始 判断比基准数大的
while (arr[j]>=base && i<j){
j-=1; //下标减一 判断前面的元素
}
//再从左边开始 判断比基准数是小的
while (arr[i]<=base && i<j){
i+=1; //下标加一 判断后面的元素
}
temp = arr[i];
arr[i] = arr[j];
arr[j] = temp;
}
//如果出了循环 代码 i=j 此时 将基准数 和 下标重合的数调换位置
arr[left] = arr[i];
arr[i]= base;
//两边位置调整好了 以后 开始对左边的进行第二轮快排
quickSort(arr,left,i-1); //基准数前面一个位置 所以是 i-1
//对右边进行第二轮快排
quickSort(arr,j+1,right);
}
}