priority_queue.h 1.3 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859
  1. /*
  2. * Copyright (c) 2012-2014 Daniele Bartolini and individual contributors.
  3. * License: https://github.com/taylor001/crown/blob/master/LICENSE
  4. */
  5. #pragma once
  6. #include "container_types.h"
  7. #include "array.h"
  8. #include <algorithm>
  9. namespace crown
  10. {
  11. /// Functions to manipulate PriorityQueue.
  12. ///
  13. /// @ingroup Containers
  14. namespace priority_queue
  15. {
  16. /// Returns the first item in the queue.
  17. template <typename T> const T& top(const PriorityQueue<T>& q);
  18. /// Inserts @a item into the queue.
  19. template <typename T> void push(PriorityQueue<T>& q, const T& item);
  20. /// Removes the first item from the queue.
  21. template <typename T> void pop(PriorityQueue<T>& q);
  22. } // namespace priority_queue
  23. namespace priority_queue
  24. {
  25. template <typename T>
  26. const T& top(const PriorityQueue<T>& q)
  27. {
  28. return array::front(q._queue);
  29. }
  30. template <typename T>
  31. void push(PriorityQueue<T>& q, const T& item)
  32. {
  33. array::push_back(q._queue, item);
  34. std::push_heap(array::begin(q._queue), array::end(q._queue));
  35. }
  36. template <typename T>
  37. void pop(PriorityQueue<T>& q)
  38. {
  39. std::pop_heap(array::begin(q._queue), array::end(q._queue));
  40. array::pop_back(q._queue);
  41. }
  42. } // namespace priority_queue
  43. template <typename T>
  44. PriorityQueue<T>::PriorityQueue(Allocator& a)
  45. : _queue(a)
  46. {
  47. }
  48. } // namespace crown