快速排序的原理:选择一个关键值作为基准值。比较基准值小的都放在左边序列(一般是无序的), 比基准值大的都在右边(一般是无序的)。一般选择序列的第一个元素。
一次循环:从后往前比较,用基准值和最后一个值比较,如果比基准值小的交换位置,如果没有继续比较下一个,知道找到第一个比基准值小的值才交换。找到这个值之后,又从前往后开始比较,如果有比基准值大的,交换位置,如果没有继续比较下一个,直到找到第一个比基准值大的值才交换。直到从前往后的比较索引>从后往前比较的索引,结束第一次比较的索引,结束第一次循环,此时,对于基准值来说,左右两边就是有序的了。
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36
| public void sort(int[] a, int low, int high){ int start = low; int end = high; int key = a[low]; while(end>start){ while(end>start && a[end]>=key){ end--; if(a[end]<=key){ int temp = a[end]; a[end] = a[start]; a[start] = temp; } while(end>start && a[start]<=key){ start++; } if(a[start]>=key){ int temp = a[start]; a[start] = a[end]; a[end] = temp; } } if(start>low){ sort(a,low,start-1); } if(end<hight){ sort(a,end+1,high); } } }
|