排序算法--快速排序

算法思想:
树立一个基准数(以此数作为比较的标杆),分别从数组两边进行探测查找,右边的探测结束条件为找到一个比基准数小的数,左边的探测结束条件为找到一个基准数大的数,当左右两边的探测都结束后,交换这两个数;重复以上过程,直到两边探测的索引相遇(一致)。最后将基准数与索引相遇的位置上的数交换。废话不多说,上图:
假设我们对{6,1,2,7,9,3,4,5,10,8}这10个数进行排序。

20180802182433217.png

注:i,j分别为左右两端的探测,姑且称它们为哨兵,首先哨兵j开始出动。因为此处设置的基准数是最左边的数,所以需要让哨兵j先出动,否则会出现递归无法退出的情况。哨兵j一步一步地向左挪动(即j--),直到找到一个小于6的数停下来,接下来哨兵i再一步一步向右挪动(即i++),直到找到一个大于6的数停下来。最后哨兵j停在了数字5面前,哨兵i停在了数字7面前。


20180802183238258.png

交换哨兵i和哨兵j所指向元素的值,交换后序列如下:
6 1 2 5 9 3 4 7 10 8
到此,第一次交换结束。接下来哨兵继续向左挪动。它发现了4之后停了下来。哨兵i也继续向右挪动,它发现9之后停了下来。此时再次进行交换,再次进行交换,交换之后的序列如下:
6 1 2 5 4 3 9 7 10 8

20180802183238258.png

第二次交换结束,探测继续。哨兵j继续向左挪动,它发现了3之后又停了下来。此时哨兵i和哨兵j相遇了,哨兵i和哨兵j都走到3面前。说明此时探测结束。我们将基准数6和3进行交换。交换之后的序列如下。
3 1 2 5 4 6 9 7 10 8

20180802190301222.png

到此第一轮探测真正结束,此时以6为分界点,6左边的数都小于等于6,6右边的数都大于等于。
此时我们已经将原来的序列以6为分界点拆分成了两个序列,左边序列{3,1,2,5,4},右边序列{9,7,10,8},接下来只需要再以上述同样的方法对这两个序列分别进行排序即可。

快排的java实现:

public class QuickSortTest {
    public void quickSort(int[] arr,int left,int right){
        if(left > right)
            return;
        int i = left;
        int j = right;
        int temp = arr[left];

        while(i!=j){
            while(i<j && arr[j]>=temp)
                j--;
            while(i<j && arr[i]<=temp)
                i++;

            if(i<j){
                int t = arr[i];
                arr[i] = arr[j];
                arr[j] = t;
            }

        }

        arr[left] = arr[i];
        arr[i] = temp;

        quickSort(arr,left,i-1);
        quickSort(arr,i+1,right);
    }
}
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 转自 坐在马桶上看算法:快速排序转自 坐在马桶上看算法:快速排序算法的精髓在于,跟它一比高数也显得那么生动活泼…。...
    Wide_Star阅读 265评论 0 0
  • 高快省的排序算法 有没有既不浪费空间又可以快一点的排序算法呢?那就是“快速排序”啦!光听这个名字是不是就觉得很高端...
    博弈史密斯阅读 416评论 0 0
  • 假设我们现在对“6 1 2 7 9 3 4 5 10 8”这个10个数进行排序。首先在这个序列中随便...
    小陈阿飞阅读 904评论 0 1
  • 上一节的冒泡排序可以说是我们学习的第一个真正的排序算法,并且解决了桶排序浪费空间的问题,但在算法的执行效率上却牺牲...
    青葱烈马阅读 676评论 0 1
  • “梁老师,你班的孩子午休时说去大便,进去后很久都不出来,你知道他在里面干什么吗?研究便便!”…… 听着值日老师声情...
    甄我心阅读 478评论 0 2