Существует ли простой способ сделать минимальную "кучу" в C++?

Я очень плохо знаком с C++, и я задавался вопросом, был ли способ сделать минимальную "кучу" в C++ из стандартной библиотеки.

18
задан Brian Tompsett - 汤莱恩 8 November 2015 в 19:15
поделиться

2 ответа

Используйте make_heap() и друзей, определенных в , или используйте priority_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;
}
36
ответ дан 30 November 2019 в 07:08
поделиться

Вы можете использовать std::make_heap, std::push_heap и другие непосредственно, или вы можете использовать std::priority_queue, построенный на std::vector или подобном.

Методы std::*_heap находятся в , а шаблон std::priority_queue - в .

4
ответ дан 30 November 2019 в 07:08
поделиться
Другие вопросы по тегам:

Похожие вопросы: