算法--快速排序(源自啊哈!算法)

算法思想:
树立一个基准数(以此数作为比较的标杆),分别从数组两边进行探测查找,右边的探测结束条件为找到一个比基准数小的数,左边的探测结束条件为找到一个基准数大的数,当左右两边的探测都结束后,交换这两个数;重复以上过程,直到两边探测的索引相遇(一致)。最后将基准数与索引相遇的位置上的数交换。废话不多说,上图: 
假设我们对{6,1,2,7,9,3,4,5,10,8}这10个数进行排序。
这里写图片描述
注:i,j分别为左右两端的探测,姑且称它们为哨兵,首先哨兵j开始出动。因为此处设置的基准数是最左边的数,所以需要让哨兵j先出动,否则会出现递归无法退出的情况。哨兵j一步一步地向左挪动(即j–),直到找到一个小于6的数停下来,接下来哨兵i再一步一步向右挪动(即i++),直到找到一个大于6的数停下来。最后哨兵j停在了数字5面前,哨兵i停在了数字7面前。
这里写图片描述
交换哨兵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

这里写图片描述

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

这里写图片描述

到此第一轮探测真正结束,此时以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);
    }
}
  • 4
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值