【22】-快速排序随机选择元素的优雅解法

关于常规解法,请参考上一篇博客,链接如下:

面试之路(19)-快速排序详解

介绍一种优雅的解法

public int partition(int data[],int length,int start,int end) throws Exception{
        if(data == null || length <= 0||start < 0||end >= length){
            throw new Exception("invalid data");
        }
        //RandomInrange是一个随机函数,随机选取start和end中间的随机值
        int index = RandomInrange(start,end);
        //swap是一个交换函数
        swap(data[index],data[end]);
        int small = start -1;
        for(index = start; index < end;index++){
            if(data[index] < data[end]){
                ++small;
                if(small != index){
                    data[small] = data[index];
                }
            }
        }
        small++;
        swap(data[small],data[end]);
        return small;
    }
    static void quicksort(int n[], int length,int left, int right) {
        //对特殊值和边界值的检查,提高程序的鲁棒性
        if(n == null || left < 0){
        return;}
        int dp;
        if (left < right) {
            dp = partition(n, length,left, right);
            quicksort(n, length,left, dp - 1);
            quicksort(n, length,dp + 1, right);
        }
    }
  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值