有没有一种简单的方法可以在C++中创建最小堆?

Ale*_*lex 18 c++ heap min data-structures

我是C++的新手,我想知道是否有办法在标准库中用C++创建最小堆.

wil*_*ell 36

使用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;
}
Run Code Online (Sandbox Code Playgroud)

  • 为(巧妙地)指出`priority_queue`是最大堆的+1. (12认同)

jem*_*nch 3

您可以直接使用std::make_heapstd::push_heap、 等,也可以使用std::priority_queue基于 a 构建的std::vector或类似的。

方法std::*_heap在 中<algorithm>,模板std::priority_queue在 中<queue>

  • 为了更清楚地说明,“priority_queue”是一个**最大**堆,如果您想要一个最小堆,则必须使用“std::greater”作为比较器。请参阅威廉的回答。 (14认同)