Я очень новичок в C++, и мне было интересно, есть ли способ сделать кучу минут в C++ из стандартной библиотеки.Есть ли простой способ сделать кучу минут в C++?
ответ
Вы можете использовать std::make_heap
, std::push_heap
и другие напрямую, или вы можете использовать std::priority_queue
, построенный на основе std::vector
или аналогичного.
Методы std::*_heap
находятся в <algorithm>
и std::priority_queue
шаблон находится в <queue>
.
Чтобы уточнить: 'priority_queue
ой, если я выскочил из priority_queue в C++, я бы получил значение min? – Alex
Чтобы уточнить, шаблон '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
- 1. Есть ли более простой способ сделать это?
- 2. Есть ли простой способ сделать код TextBox?
- 3. Есть ли простой способ сделать document.getElementById упрощенным?
- 4. Есть ли простой способ сделать ScrollViewer "bouncy"?
- 5. Есть ли более простой способ сделать это?
- 6. Есть ли простой способ сделать изображения наклонными?
- 7. Есть ли простой способ сделать складной QWidget?
- 8. Что такое самый простой и эффективный способ сделать кучу минут в Scala?
- 9. Есть ли еще один простой способ сделать C++-свойства?
- 10. Есть ли способ сделать currying в C?
- 11. Есть ли простой способ сделать gcc пропустить crtbegin.o/crtend.o?
- 12. Есть ли простой способ сделать параллельную агрегацию с некоммутативной операцией?
- 13. Есть ли простой способ сделать json-данные в mysql?
- 14. Есть ли простой способ сделать запрос по примеру в iBATIS?
- 15. Есть ли простой способ сделать это в OpenCV?
- 16. Есть ли простой способ сделать многострочные отступы в Ruby?
- 17. Есть ли простой простой и элегантный способ сделать ICollection более свободным в C#?
- 18. Есть ли более простой способ сделать это, если утверждение?
- 19. Есть ли лучший способ разместить кучу вещей в NSUserDefaults?
- 20. Есть ли лучший способ сделать это (C#)?
- 21. Есть ли простой способ изменить символ в строке на C#?
- 22. Есть ли более простой способ, чем использование #ifdef в C?
- 23. R: Есть ли простой способ сделать работу ave() для матриц?
- 24. Есть ли простой способ обратного преобразования шаблона?
- 25. Сериализация объектов в C# 4.0, есть ли более простой способ?
- 26. Есть ли более простой способ представления условий в C++?
- 27. Есть ли простой способ конвертировать кучу переменных одного типа в другой тип в python
- 28. Есть ли простой способ сортировки CObList?
- 29. Email Subtitle - Есть ли простой способ сделать это?
- 30. Есть ли простой способ сделать ошибки GORM restful api friendly
Вы задаете вопросы и не принимаете их. Это поведение по привычке или выбору? – Siddharth