力扣面试150 查找和最小的 K 对数字 最小堆 去重

Problem: 373. 查找和最小的 K 对数字

👨‍🏫 参考题解

Java 复制代码
class Solution {
    public List<List<Integer>> kSmallestPairs(int[] nums1, int[] nums2, int k) {
        // 创建一个大小为 k 的结果列表,用于存储和最小的 k 个数对
        List<List<Integer>> ans = new ArrayList<>(k); // 预分配空间
        
        // 创建一个优先队列(小根堆),存储三元组 [nums1[i] + nums2[j], i, j]
        // 按照和 (nums1[i] + nums2[j]) 的大小升序排列
        PriorityQueue<int[]> pq = new PriorityQueue<>((a, b) -> a[0] - b[0]);
        
        // 将 nums1 中前 k 个元素与 nums2 中第一个元素的和及其索引 i, j 加入到优先队列中
        for (int i = 0; i < Math.min(nums1.length, k); i++) { // 至多 k 个
            pq.add(new int[]{nums1[i] + nums2[0], i, 0});
        }
        
        // 循环直到找到 k 个数对或者优先队列为空
        while (ans.size() < k && !pq.isEmpty()) {
            // 取出堆顶元素,也就是当前和最小的数对
            int[] p = pq.poll();
            int i = p[1]; // 取出 nums1 的索引
            int j = p[2]; // 取出 nums2 的索引
            
            // 将当前和最小的数对加入结果列表
            ans.add(List.of(nums1[i], nums2[j]));
            
            // 如果 nums2 中还有剩余元素,将新的数对 [nums1[i], nums2[j + 1]] 放入优先队列
            if (j + 1 < nums2.length) {
                pq.add(new int[]{nums1[i] + nums2[j + 1], i, j + 1});
            }
        }
        
        // 返回结果列表
        return ans;
    }
}
相关推荐
hid64663722几秒前
基于Matlab的含分布式电源配电网模型图:故障点设置与潮流计算下的短路电压电流波形展示
算法
小年糕是糕手4 分钟前
【C++】内存管理(上)
java·开发语言·jvm·c++·算法·spring·servlet
晚风(●•σ )8 分钟前
【数据结构】——算法设计范式的相关习题
数据结构·算法·贪心算法·深度优先·动态规划·剪枝·广度优先
啊吧怪不啊吧9 分钟前
算法王冠上的明珠——动态规划之斐波那契数列问题(第二篇)
大数据·算法·leetcode·动态规划
拾光Ծ14 分钟前
【Linux】深入理解“进程”:进程状态 -> Linux内核O(1)调度算法
linux·运维·服务器·算法
CoderYanger18 分钟前
动态规划算法-两个数组的dp(含字符串数组):41.最长公共子序列(模板)
java·算法·leetcode·动态规划·1024程序员节
阿正的梦工坊21 分钟前
FlowBench论文阅读:Workflow-Guided Planning for LLM-based Agents
人工智能·算法·大模型·llm
2401_8604947022 分钟前
在React Native鸿蒙跨平台开发中实现一个基数排序算法,如何进行找到最大数:遍历数组找到最大值呢?
javascript·算法·react native·react.js·排序算法·harmonyos
Watermelo61724 分钟前
如何优雅地导出 VS Code 项目目录结构
前端·javascript·vue.js·vscode·算法·性能优化·node.js
飞Link28 分钟前
【算法与模型】One-Class SVM 异常检测全解析:原理、实例、项目实战与工程经验
人工智能·python·算法·机器学习·支持向量机