牛客-NC88-寻找第K大

NC88. 寻找第K大(medium)


方法一:栈法

思路:同牛客-NC119-最小的K个数,求第K大等价于在小根堆中求第N-K+1小,所有改变遍历次数即可:

import java.util.*;

public class Solution {
   
    public int findKth(int[] a, int n, int K) {
   
        // write code here
        // 特判
        int ret = 0;
        if (n == 0 || K > n) {
   
            return ret;
        }

        PriorityQueue<Integer> pq = new PriorityQueue();
        for (int i = 0; i < n; i++) {
   
            pq.offer(a[i]);
        }
        for (int i = 0; i <= n - K; i++) {
   
            ret = pq.poll();
        }
        return ret;
    }
}

时间复杂度: O(NlogN),建小根堆所需的时间复杂度。
空间复杂度: O(N), 我们使用大小为N的PriorityQueue来存数据。

全部评论

相关推荐

07-15 12:24
重庆大学 运营
坏消息:和好工作擦肩而过
给点吧求求了:怎么可能因为差几秒,估计就是简历更好看婉拒了
点赞 评论 收藏
分享
Lorn的意义:1.你这根本就不会写简历呀,了解太少了 2.你这些项目经历感觉真的没啥亮点啊,描述的不行,重写书写一下让人看到核心,就继续海投 注意七八月份ofer还是比较多的,越往后机会越少,抓住时机,抓紧检查疏漏,加油查看图片
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

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