切分算法(摘自算法第四版)

          快速排序算法(二):切分方法

对于切分方法的实现,一般的方法是随机取出a[lo]作为切分元素,也就是上一篇文章中提到的’K’,然后我们从数组的左端开始向右扫描直到找到一个不小于它的元素,同样道理,再从数组的右端开始向左扫描直到找到一个不大于的元素。然后再将这两个元素交换位置,如此这样继续,这样就保证了’K’左边的元素从整体上来看是不大于’K’右边的元素。当两个指针相遇时,我们只需要将切分元素a[lo]和左子数组最右侧的元素交换,然后返回最右侧元素的下标(也即是元素的位置)即可。
切分排序算法(摘自算法第四版–快速排序)

private static int partition(Comparable[] a,int lo,int hi)
{
    int i=lo;
    int j=hi+1;

    Comparable v=a[lo];//切分元素

    while(true)
    {
        //扫描左右
        while(less(a[++i],v))
        {
            if(i==hi)
                break;
        }

        while(less(v,a[--j]))
        {
            if(i==lo)
            {
                break;
            }
        }

        if(i>=j)
        {
            break;
        }

        exch(a,i,j); //交换值

    }

    exch(a,lo,j);//将v放入正确的位置
    return j; //v左边的元素整天不大于左边的元素
}
  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值