A股上市公司传智教育(股票代码 003032)旗下技术交流社区北京昌平校区

 找回密码
 加入黑马

QQ登录

只需一步,快速开始

【南京校区】排序算法之快速排序



      排序算法中,大家用的非常多的就是冒泡算法和选择算法,但是这些的速度都不是最快的。
      我们翻看JDK源码,很多源码中用的是快速排序,代码复杂,但是速度确实要比冒泡,选择快速很多。下面就对快排进行讲解。
       其原理是:先选一个“标尺”,

       用它把整个队列过一遍筛子,
      以保证:其左边的元素都不大于它,其右边的元素都不小于它。

      这样,排序问题就被分割为两个子区间。
      再分别对子区间排序就可以了。

        public static int partition(int []array,int lo,int hi){

        //固定的切分方式        int key=array[lo];        while(lo<hi){            while(array[hi]>=key&&hi>lo){//从后半部分向前扫描                hi--;            }            array[lo]=array[hi];            while(array[lo]<=key&&hi>lo){从前半部分向后扫描                lo++;            }            array[hi]=array[lo];        }        array[hi]=key;        return hi;    }        public static void sort(int[] array,int lo ,int hi){        if(lo>=hi){            return ;        }        int index=partition(array,lo,hi);        sort(array,lo,index-1);        sort(array,index+1,hi);     }

    是冒泡排序的改进型。首先在数组中选择一个基准点(该基准点的选取可能影响快速排序的效率,后面讲解选取的方法),然后分别从数组的两端扫描数组,设两个指示标志(lo指向起始位置,hi指向末尾),首先从后半部分开始,如果发现有元素比该基准点的值小,就交换lo和hi位置的值,然后从前半部分开始扫秒,发现有元素大于基准点的值,就交换lo和hi位置的值,如此往复循环,直到lo>=hi,然后把基准点的值放到hi这个位置。一次排序就完成了。以后采用递归的方式分别对前半部分和后半部分排序,当前半部分和后半部分均有序时该数组就自然有序了。     画了一张小图   

0 个回复

您需要登录后才可以回帖 登录 | 加入黑马