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;
}
};