有没有一种简单的方法可以在C++中创建最小堆?
您可以直接使用std::make_heap
,std::push_heap
等,或者您可以使用建立在std::vector
或类似物上的std::priority_queue
。
std::*_heap
方法在<algorithm>
,而std::priority_queue
模板在<queue>
。
澄清:'priority_queue
哦,所以如果我从C++中的priority_queue弹出我会得到最小值? – Alex 2010-05-07 05:39:22
为了进一步阐明,'priority_queue'的整个模板接受一个容器类型,默认为'vector
使用make_heap()
和朋友,在<algorithm>
中定义或使用priority_queue
,在<queue>
中定义。 priority_queue
使用make_heap
和底下的朋友。
#include <queue> // functional,iostream,ctime,cstdlib
using namespace std;
int main(int argc, char* argv[])
{
srand(time(0));
priority_queue<int,vector<int>,greater<int> > q;
for(int i = 0; i != 10; ++i) q.push(rand()%10);
cout << "Min-heap, popped one by one: ";
while(! q.empty()) {
cout << q.top() << ' '; // 0 3 3 3 4 5 5 6 8 9
q.pop();
}
cout << endl;
return 0;
}
+1(微妙地)指出'priority_queue'是一个最大堆。 – avakar 2010-05-07 08:29:55
您提出问题并且不接受任何答案。这是习惯还是选择? – Siddharth 2014-09-24 05:06:46