题解 | #寻找第K大#

寻找第K大

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

快速排序

快速排序在笔试中应该是比较常见的了 下面附上了快排比较简单的实现代码,也可以用 Arrays.sort(a); 调用

注意:在递归处理左右两边时候,注意选取的分割点,搞不好会死循环的。

import java.util.*;

public class Solution {
    public int findKth(int[] a, int n, int k) {
        //Arrays.sort(a);
        quick_sort(a,0,n - 1);
        return a[n - k];
    }
    public void quick_sort(int arr[],int l,int r){
        if(l >= r)return;
        int i = l - 1,j = r + 1;
        int mid = arr[l + r >> 1];
        while(i < j){
            do{
               i++;
            }while(arr[i] < mid);
            do{
                j--;
            }while(arr[j] > mid);
            if(i < j){
                int tmp = arr[i];
                arr[i] = arr[j];
                arr[j] = tmp;
            }
        }
        quick_sort(arr,l,j);
        quick_sort(arr,j + 1,r);
    }
}
全部评论

相关推荐

不愿透露姓名的神秘牛友
11-21 11:29
已编辑
斯卡蒂味的鱼汤:知道你不会来数马,就不捞你😂最近数马疯狂扩招,招聘要求挺低的,你能力肯定够,应该就是因为太强了,知道你不会来才不捞你
投递腾讯云智研发等公司10个岗位
点赞 评论 收藏
分享
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务