力扣373. 查找和最小的 K 对数字

优先队列

  • 思路:
    • 使用下标 (x, y) 标识数值对,x 为第一个数组的下标,y 为第二个数组的下标;
    • 所以 k 个数值对 x 的范围属于 [0, min(k, m)],m 为第一个数组的 size;
    • 数值对 (x, y) ,那么下一个比其大的数组对是 min{(x, y + 1), (x + 1, y)};
    • 可以先固定 x ,即将 x 可能的值全选,来动态变更 y;
    • 构建一个优先队列,存放的是 (x, y),小顶堆,即其对应的数值对的和最小的总是在堆顶:nums1[a.first] + nums2[a.second] > nums1[b.first] + nums2[b.second];
    • 将小顶堆取 k 次堆顶即可,每次之后将 (x, y + 1) 入堆即可;
class Solution {
public:
    vector<vector<int>> kSmallestPairs(vector<int>& nums1, vector<int>& nums2, int k) {
        auto cmp = [&nums1, &nums2](const std::pair<int, int>& a, const std::pair<int, int>& b) {
            return nums1[a.first] + nums2[a.second] > nums1[b.first] + nums2[b.second];
        };

        int m = nums1.size();
        int n = nums2.size();

        std::vector<std::vector<int>> result;
        std::priority_queue<std::pair<int, int>, std::vector<std::pair<int, int>>, decltype(cmp)> pq(cmp);

        for (int i = 0; i < std::min(k, m); i++) {
            pq.emplace(i, 0);
        }

        while (k-- > 0 && !pq.empty()) {
            auto [x, y] = pq.top();
            pq.pop();
            result.push_back(std::initializer_list<int>{nums1[x], nums2[y]});

            if (y + 1 < n) {
                pq.emplace(x, y + 1);
            }
        }
        
        return result;
    }
};

相关推荐

  1. 373. 查找 K 数字

    2023-12-12 01:02:02       51 阅读
  2. 373.查找K数字

    2023-12-12 01:02:02       32 阅读
  3. Leetcode373.查找 K 数字

    2023-12-12 01:02:02       26 阅读
  4. 2336.无限集中数字

    2023-12-12 01:02:02       22 阅读
  5. 209-长度数组

    2023-12-12 01:02:02       65 阅读

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2023-12-12 01:02:02       94 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2023-12-12 01:02:02       100 阅读
  3. 在Django里面运行非项目文件

    2023-12-12 01:02:02       82 阅读
  4. Python语言-面向对象

    2023-12-12 01:02:02       91 阅读

热门阅读

  1. 通义千问测试

    2023-12-12 01:02:02       55 阅读
  2. 使用OkHttp上传本地图片及参数

    2023-12-12 01:02:02       58 阅读
  3. 空间信息智能应用团队研究成果与人才引进

    2023-12-12 01:02:02       52 阅读
  4. Zookeeper面试题

    2023-12-12 01:02:02       60 阅读
  5. 安装CAS登录服务器

    2023-12-12 01:02:02       57 阅读
  6. C++ Primer Plus第十五章笔记

    2023-12-12 01:02:02       38 阅读
  7. RK3568 CIF和ISP的关联

    2023-12-12 01:02:02       65 阅读