快速排序
英文:QuickSort一、快速排序原理
- 从待排序区间选择一个数,作为基准值(pivot);
- Partition: 遍历整个待排序区间,将比基准值小的(可以包含相等的)放到基准值的左边,将比基
准值大的(可以包含相等的)放到基准值的右边; - 采用分治思想,对左右两个小区间按照同样的方式处理,直到小区间的长度 == 1,代表已经有序,或者小区间的长度 == 0,代表没有数据。
二、性能分析
时间复杂度:平均 O( n * log(n) )
空间复杂度:
稳定性:不稳定
三、代码实现
1.原理
代码如下(示例):
//快速排序
public static void quickSort(int[] arr){
//使用一个辅助方法进行递归
//辅助方法多了两个参数,用来表示针对数组上的哪个区间
//进行整理
_quickSort(arr, 0 ,arr.length - 1);
}
//[left, right]
public static void _quickSort(int[] arr, int left, int right){
if(left >= right){
//如果区间为空或者区间只有一个元素,不用排序
return;
}
//使用 partition 方法来进行刚才描述的整理过程
// index 就是 left 和 right 重合的位置,就是整理之后的基准值的位置
int index = partition(arr, left, right);
//递归处理左边区间
_quickSort(arr, left, index - 1);
//递归处理右边区间
_quickSort(arr, index + 1, right);
}
private static int partition(int[] arr, int left, int right) {
//选取基准值(以最右侧数为基准值)
int v = arr[right];
int i = left;
int j = right;
while(i < j){
//先从左往右找到一个比基准值大的元素
while (i < j && arr[i] <= v){
i++;
}
//再从右往左找到一个比基准值小的元素
while (i < j && arr[j] >= v){
j--;
}
swap(arr, i, j);
}
//如果发现 i 和 j 重叠了,此时就需要把当前基准值元素
// 和 i,j 重叠位置进行交换
swap(arr, i, right);
return i;
}
2.main函数部分验证
代码如下(示例):
public static void main(String[] args) {
int[] arr = {9,5,2,7,3,6,8};
quickSort(arr);
System.out.println(Arrays.toString(arr));
}
四、如何优化
- 选择基准值很重要,通常使用几数取中法
- partition 过程中把和基准值相等的数也选择出来
- 待排序区间小于一个阈值时(例如 48),使用直接插入排序
总结
以上就是今天要讲的内容,本文介绍了快速排序的使用,欢迎评论区留言,我们共同探讨问题!