c++优先队列priority_queue(自定义比较函数)_c++优先队列自定义比较-CSDN博客
373. 查找和最小的 K 对数字 - 力扣(LeetCode)

官方题解:
class Solution {
public:
    vector<vector<int>> kSmallestPairs(vector<int>& nums1, vector<int>& nums2, int k) {
        auto cmp = [&nums1,&nums2](const pair<int,int>& a,const 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();
        vector<vector<int>> ans;
        priority_queue<pair<int,int>,vector<pair<int,int>>,decltype(cmp)> pq(cmp);
        for(int i = 0;i < min(k,m);i++) {
            pq.emplace(i,0);
        }
        while(k-- > 0 && !pq.empty()) {
            auto [x,y] = pq.top();
            pq.pop();
            ans.emplace_back(initializer_list<int>{nums1[x],nums2[y]});
            if(y + 1 < n) {
                pq.emplace(x,y + 1);
            }
        }
        return ans;
    }
};
![[OPEN SQL] SELECT语句](https://i-blog.csdnimg.cn/direct/65634126c0b14030934dfc72c4721dd1.png)
![[数据结构]动态顺序表的实现与应用](https://i-blog.csdnimg.cn/direct/f5c016efacaa400b8762ad82e844ebfc.png)
















