算法题目---优先级队列

(一).基础概念

优先级队列,也称为堆。在前面介绍数据结构章节介绍过了,所以这里就不多介绍了,直接上题目。

(二).具体题目

1.最后一块石头的重量

1046. 最后一块石头的重量 - 力扣(LeetCode)

解法:使用优先级队列

java 复制代码
class Solution {
    public int lastStoneWeight(int[] stones) {
        PriorityQueue<Integer> priorityQueue=new PriorityQueue<>(new Comparator<Integer>() {
            @Override
            public int compare(Integer o1, Integer o2) {
                return o2-o1;
            }
        });

        for(int x:stones){
            priorityQueue.add(x);
        }
        while (priorityQueue.size()>1){
            int v1=priorityQueue.poll();
            int v2=priorityQueue.poll();
            if (v1-v2!=0){
                priorityQueue.add(v1-v2);
            }
        }
        return priorityQueue.size()>=1?priorityQueue.peek():0;
    }
}

2.数据流中的第K大元素

703. 数据流中的第 K 大元素 - 力扣(LeetCode)

解法:使用优先级队列

java 复制代码
class KthLargest {

    PriorityQueue<Integer> priorityQueue=new PriorityQueue<>(new Comparator<Integer>() {
        @Override
        public int compare(Integer o1, Integer o2) {
            return o1-o2;
        }
    });
    int size;
    public KthLargest(int k, int[] nums) {
        size=k;
        for (int i = 0; i < nums.length; i++) {
            priorityQueue.add(nums[i]);
            if (priorityQueue.size()>k){
                priorityQueue.poll();
            }
        }
    }

    public int add(int val) {
        priorityQueue.add(val);
        if (priorityQueue.size()>size){
            priorityQueue.poll();
        }
        return priorityQueue.peek();
    }
}

3.前K个高频单词

692. 前K个高频单词 - 力扣(LeetCode)

解法:使用优先级队列

java 复制代码
    public List<String> topKFrequent(String[] words, int k) {
        HashMap<String,Integer> hashMap=new HashMap<>();
        for(String word:words){
            hashMap.put(word,hashMap.getOrDefault(word,0)+1);
        }

        PriorityQueue<Map.Entry<String,Integer>> priorityQueue=new PriorityQueue<>(new Comparator<Map.Entry<String, Integer>>() {
            @Override
            public int compare(Map.Entry<String, Integer> o1, Map.Entry<String, Integer> o2) {
                if (o1.getValue().compareTo(o2.getValue())==0){
                    return o2.getKey().compareTo(o1.getKey());
                }
                return o1.getValue().compareTo(o2.getValue());
            }
        });

        for(Map.Entry<String,Integer> entry:hashMap.entrySet()){
            priorityQueue.add(entry);
            if (priorityQueue.size()>k){
                priorityQueue.poll();
            }
        }
        List<String> list=new ArrayList<>();
        for (int i = 0; i < k; i++) {
            list.add(priorityQueue.poll().getKey());
        }
        Collections.reverse(list);
        return list;
    }

4.数据流的中位数

295. 数据流的中位数 - 力扣(LeetCode)

解法:使用优先级队列

java 复制代码
class MedianFinder {


    PriorityQueue<Integer> leftQueue;
    PriorityQueue<Integer> rightQueue;

    public MedianFinder() {
        leftQueue=new PriorityQueue<>(new Comparator<Integer>() {
            @Override
            public int compare(Integer o1, Integer o2) {
                return o2.compareTo(o1);
            }
        });

        rightQueue=new PriorityQueue<>(new Comparator<Integer>() {
            @Override
            public int compare(Integer o1, Integer o2) {
                return o1.compareTo(o2);
            }
        });
    }

    public void addNum(int num) {
        if (leftQueue.size()==rightQueue.size()){
            if (leftQueue.isEmpty() || num<=leftQueue.peek()){
                leftQueue.add(num);
            }else{
                rightQueue.add(num);
                leftQueue.add(rightQueue.poll());
            }
        }else{
            if (num<=leftQueue.peek()){
                leftQueue.add(num);
                rightQueue.add(leftQueue.poll());
            }else {
                rightQueue.add(num);
            }
        }
    }

    public double findMedian() {
        if (leftQueue.size()>rightQueue.size()){
            return leftQueue.peek();
        }else{
            return (leftQueue.peek()+rightQueue.peek())/2.0;
        }
    }
}
相关推荐
To_OC9 小时前
LC 1 两数之和:面试第一道必考题,暴力解法直接被面试官 pass
javascript·算法·leetcode
鱼鱼不愚与13 小时前
《原来如此 | 第01期:为什么导航软件能预测红绿灯倒计时?》
算法
复杂网络18 小时前
论最小 Agent 计算机的形态
算法
kisshyshy1 天前
🍦 雪糕、食堂、火车厢:三幅漫画吃透栈、队列与链表
javascript·算法
猿人谷2 天前
不只是 CPU 阈值:STAR 如何用 GAT + Transformer 做容器级自动扩缩容?
人工智能·算法
复杂网络2 天前
Stable Diffusion 视觉大模型微调技术深度调研
算法
复杂网络2 天前
基于 Stable Diffusion 架构的视觉大模型代表性工作与原理深度解析
算法
MrZhao4002 天前
Agent Loop 如何用 Hook 扩展:权限、日志与工具拦截
算法
MrZhao4002 天前
Agent 为什么需要 Skills:别把所有知识都塞进 system prompt
算法