排序之快速排序

package QuickSort;

import MergeSort.MegerSort;
import chooseSort.Example;

/**
 * 快速排序
 * 思想:分而治之;
 * 不断地以第一个元素为基准对当前数组进行分割,直到子数组只有一个元素
 */
public class QuickSort extends Example
{
    public void sort(Comparable[] a, int lo,int hi) {
        if (lo>=hi) return;
        int j = partition(a,lo,hi); //原地切分
        sort(a,lo,j-1);
        sort(a,j+1,hi);
    }

    private int partition(Comparable[] a, int lo, int hi) {
        int i = lo;
        int j = hi+1; //note
        Comparable v = a[lo];//基准数
        while (true){
            //i指向数组范围内比基准数大的值,或者数组最后一个元素
            //j指向数组范围内比基准数小的值,或者数组第一个元素
            while (less(a[++i],v)) if(i==hi) break;
            while (less(v,a[--j])) if(j==lo) break;
            //判断
            if(i>=j) break;
            //交换
            exch(a,i,j);
        }
        exch(a,lo,j);
        return j;
    }
    /**
     * 测试用例
     * @param args
     */
    public static void main(String[] args) {
        Integer[] a = new Integer[]{1,6,34,2,5,3,4,45,6,22};
        QuickSort sort = new QuickSort();
//        sort.merge(a,0,2,a.length-1);
        sort.sort(a,0,a.length-1);
        show(a);
        System.out.println(isSorted(a));
    }
}

 

posted @ 2019-06-20 15:19  由走啦啦啦  阅读(117)  评论(0编辑  收藏  举报