JAVA-快速查找算法

快速查找算法,可以根据想要找的是第几个大的数,每次循环都能固定下来一个数在数组完整排完序之后的位置,每次循环都能定一个数的位置,如果当前固定的数的位置和用户要找的第几个数匹配,则就直接返回。例如我要找第二大的数,如果循环一次固定的数的下标是1,那就是当前需要找的数。

代码如下:

    //  快速查找算法
    public static int quickSelect(int[] arr, int selectIndex) {
        int s = 0;
        int i = s+1;
        while(i < arr.length) {
            if(arr[i] < arr[0]) {
                int t = arr[s+1];
                arr[s+1] = arr[i];
                arr[i] = t;
                s += 1;
                i = s+1;
                continue;
            }
            i++;
        }

        // i找到最后之后将下表为s的值和第一个值交换
        int temp = arr[0];
        arr[0] = arr[s];
        arr[s] = temp;

        if(selectIndex-1 == s) {
            return arr[s];
        }else {
            // 将数组不需要的切掉   用后一部分去回调
            int arrs[] = new int[arr.length - s];
            for(int j = s; j < arr.length; j++) {
                arrs[j-s] = arr[j];
            }
            quickSelect(arrs, selectIndex);
        }
        return 0;
    }
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值