题解 | #寻找第K大#

寻找第K大

http://www.nowcoder.com/practice/e016ad9b7f0b45048c58a9f27ba618bf

图片说明

public static int findKth(int[] a, int n, int K) {
        // write code here
        QuickSort(a, 0, n - 1, K);
        return res;
    }

    private static void QuickSort(int[] a, int l, int r, int k) {
        if (l < r) {
            int i = l, j = r;
            while (i < j) {
                int temp = a[l];
                while (i < j && a[i] < temp) i++;
                while (i < j && a[j] >= temp) j--;
                swap(a, i, j);
            }
            swap(a, l, i);
            if (r-i+1>k){
                QuickSort(a, i+1 , r, k);
            }else if (r-i+1==k){
                res = a[i];
            }
            else {
                QuickSort(a, l, i-1, k-(r-i+1));
            }
        }
    }

    private static void swap(int[] a, int i, int j) {
        int temp = a[i];
        a[i] = a[j];
        a[j] = temp;
    }
全部评论

相关推荐

吃不饱的肱二头肌很想退休:tnnd 我以为选妹子呢,亏我兴高采烈的冲进来😠
投递快手等公司10个岗位
点赞 评论 收藏
分享
有趣的牛油果开挂了:最近这个阶段收到些杂七杂八的短信是真的烦
点赞 评论 收藏
分享
点赞 收藏 评论
分享
牛客网
牛客企业服务