Я очень новичок в С++, и мне было интересно, есть ли способ сделать кучу минут в С++ из стандартной библиотеки.
Есть ли простой способ сделать кучу минут в С++?
Ответ 1
Используйте 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;
}
Ответ 2
Вы можете использовать std::make_heap
, std::push_heap
и другие напрямую, или вы можете использовать std::priority_queue
, построенный на std::vector
или аналогичном.
Методы std::*_heap
находятся в <algorithm>
, а шаблон std::priority_queue
находится в <queue>
.