快速排序是由冒泡排序改进而得的,它的基本思想是在待排序的n个元素中人去一个元素(通常取第一个元素)作为基准数,经过第一次排序后,数据序列被分为两个部分。所有比基准数小的元素放在前面的部分,所有比基准数大的放在后面部分,这个过程称为一趟快速排序。
之后对产生的两个部分分别重复上述过程,直至每部分内只有一个元素或空为止。
以一个数组作为示例,取区间第一个数为基准数。
0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 |
---|---|---|---|---|---|---|---|---|---|
72 | 6 | 57 | 88 | 60 | 42 | 83 | 73 | 48 | 85 |
初始时,i = 0; j = 9; X = a[i] = 72
由于已经将 a[0] 中的数保存到 X 中,可以理解成在数组 a[0] 上挖了个坑,可以将其它数据填充到这来。
从j开始向前找一个比X小或等于X的数。当j=8,符合条件,将a[8]挖出再填到上一个坑a[0]中。a[0]=a[8]; i++; 这样一个坑a[0]就被搞定了,但又形成了一个新坑a[8],这怎么办了?简单,再找数字来填a[8]这个坑。这次从i开始向后找一个大于X的数,当i=3,符合条件,将a[3]挖出再填到上一个坑中a[8]=a[3]; j--;
数组变为:
0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 |
---|---|---|---|---|---|---|---|---|---|
48 | 6 | 57 | 88 | 60 | 42 | 83 | 73 | 88 | 85 |
i = 3; j = 7; X=72
再重复上面的步骤,先从后向前找,再从前向后找。
从j开始向前找,当j=5,符合条件,将a[5]挖出填到上一个坑中,a[3] = a[5]; i++;
从i开始向后找,当i=5时,由于i==j退出。
此时,i = j = 5,而a[5]刚好又是上次挖的坑,因此将X填入a[5]。
数组变为:
0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 |
---|---|---|---|---|---|---|---|---|---|
48 | 6 | 57 | 42 | 60 | 72 | 83 | 73 | 88 | 85 |
可以看出a[5]前面的数字都小于它,a[5]后面的数字都大于它。因此再对a[0…4]和a[6…9]这二个子区间重复上述步骤就可以了。
对挖坑填数进行总结:
1.i =begin; j = end; 将基准数挖出形成第一个坑a[i]。
2.j--由后向前找比它小的数,找到后挖出此数填前一个坑a[i]中。
3.i++由前向后找比它大的数,找到后也挖出此数填到后面的坑a[j]中。
4.再重复执行2,3二步,直到i==j,将基准数填入a[i]中
public class Quicksort { public void quicksort(int[] sc,int begin,int end){ if(begin<end){ //区间内至少存在两个元素的情况 int i=begin; int j=end; int temp=sc[begin]; //以sc[begin]为基准数或者说以temp为基准数 while(i<j) //从两端交替向中间扫描,直到i=j为止 { while(j>i&&sc[j]>=temp) j--; //从右向左扫描,找一个小于temp的数sc[j] sc[i]=sc[j]; //找到以后就将sc[j],放入sc[i]中 while(i<j&&sc[i]<=temp) i++; //从左向右扫描,找到一个大于temp的数sc[i] sc[j]=sc[i]; //找到以后就将sc[i],放入sc[j]中 } sc[i]=temp; //当i=j时将基准数放入sc[i]中 quicksort(sc,begin,i-1); //对左区间递归排序 quicksort(sc,i+1,end); //对右区间递归排序 } } }
下面写一段测试上面快速排序算法的代码:
public class Test { public static void main(String args[]){ int[] array={22,3,1,44,22,55,21,14,52,62,96,43}; System.out.print("数组排序前的顺序为:"); for(int i=0;i<array.length;i++){ System.out.print(array[i]+" "); } Quicksort a=new Quicksort(); a.quicksort(array,0,array.length-1); System.out.println(); System.out.print("数组排序后的顺序为:"); for(int i=0;i<array.length;i++){ System.out.print(array[i]+" "); } } }
测试结果: