multiset
和priority_queue
都是内部有序的数据结构,都可以用来实现堆,用法稍有不同。
建堆(大顶堆为例)
堆中有重复元素
使用priority_queue
:
priority_queue<int> pq; // 默认大顶堆, 小顶堆: priority_queue<int, vector<int>, greater<int>> pq;
pq.push(1); pq.push(2), ... // 添加元素
while(k-- && !pq.empty()) // 取出第k大的元素,堆内元素会减少
res = pq.top(), pq.pop();
使用multiset
:
multiset<int, greater<</