浏览 2170 次
锁定老帖子 主题:自己动手写算法之快速排序
精华帖 (0) :: 良好帖 (0) :: 新手帖 (0) :: 隐藏帖 (0)
|
|
---|---|
作者 | 正文 |
发表时间:2012-03-29
最后修改:2012-03-30
交换排序法->快速排序 public static void quickSort(Integer[] array) { if (array == null || array.length== 0) { return; } quickSort(array,0,array.length-1); }
private static void quickSort(Integer[] array, final int start, final int end){ //数组长度<=1退出 if(start>=end){ return; } //数组长度==2,比较两个元素的大小 if(end-start==1){ if(array[start]>array[end]){ swap(array,start,end); } return; } //用来进行比较的数 int compareNumber = array[start]; int middlePosition = 0; int i = start; int j = end; for(;;i++,j--){ //从数组首端开始迭代(不包括compareNumber),如果数组的数<compareNumber,不做移动 while(array[i]<compareNumber&&i<j){ i++; } //从数组尾端迭代,如果数组的数>=compareNumber,不做移动 while(array[j]>compareNumber&&i<j){ j--; } if(i>=j){ if(array[j]>compareNumber){ middlePosition = j; }else{ middlePosition = (j+1); } break; } //从数组首端开始迭代,得到大于compareNumber的数array[i],此时从尾端迭代直至得到<=compareNumber的数 //array[j],交换这两个数的位置,然后继续迭代 swap(array,i,j); } //递归排序 quickSort(array,start,middlePosition-1); quickSort(array,middlePosition,end); }
public static void swap(Object[] array,int a,int b){ Object temp = array[a]; array[a] = array[b]; array[b] = temp; }
声明:ITeye文章版权属于作者,受法律保护。没有作者书面许可不得转载。
推荐链接
|
|
返回顶楼 | |