快速排序
public class QuickSort {
public static void main(String[] args) {
int[] a = { 0, 3, 6, 8, 2, 4, 6, 9, 7, 5 };
new QuickSort().sort(a, 0, a.length-1);
System.out.println(Arrays.toString(a));
}
public void sort(int[] a, int low, int high) {
if (low < high) {
int pivotIndex = position(a, low, high);
sort(a, low, pivotIndex - 1);
sort(a, pivotIndex + 1, high);
}
}
public int position(int a[], int low, int high) {
int pivot = a[low];
while (low < high) {
while (low < high && pivot <= a[high]) {
high--;
}
a[low] = a[high];
while (low < high && a[low] <= pivot) {
low++;
}
a[high] = a[low];
}
a[low] = pivot;
return low;
}
}
算法分析:
1、最坏时间复杂度
最坏情况是每次划分选取的基准都是当前无序区中关键字最小(或最大)的记录,划分的结果是基准左边的子区间为空(或右边的子区间为空),而划分所得的另一个非空的子区间中记录数目,仅仅比划分前的无序区中记录个数减少一个。因此,快速排序必须做n-1次划分,第i次划分开始时区间长度为n-i+1,所需的比较次数为n-i(1≤i≤n-1),故总的比较次数达到最大值:C= n(n-1)/2=O(n)
2、最好时间复杂度
在最好情况下,每次划分所取的基准都是当前无序区的"中值"记录,划分的结果是基准的左、右两个无序子区间的长度大致相等。总的关键字比较次数:0(nlgn)
因为快速排序的记录移动次数不大于比较的次数,所以快速排序的最坏时间复杂度应为0(n),最好时间复杂度为O(nlgn)。
3、空间复杂度
快速排序在系统内部需要一个栈来实现递归。若每次划分较为均匀,则其递归树的高度为O(lgn),故递归后需栈空间为O(lgn)。最坏情况下,递归树的高度为O(n),所需的栈空间为O(n)。
4、稳定性
快速排序是非稳定的。