【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);
        }
    }

欢迎入群:

公众号IT面试题汇总讨论群

这里写图片描述

如果扫描不进去,加我微信(rdst6029930)拉你。

扫我微信二维码加我

这里写图片描述

欢迎关注《IT面试题汇总》微信订阅号。每天推送经典面试题和面试心得技巧,都是干货!

微信订阅号二维码如下:

这里写图片描述

转载于:https://my.oschina.net/fengsehng/blog/784430

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值