min_heap.h 690 B

123456789101112131415161718192021
  1. // This file is part of libigl, a simple c++ geometry processing library.
  2. //
  3. // Copyright (C) 2020 Alec Jacobson <[email protected]>
  4. //
  5. // This Source Code Form is subject to the terms of the Mozilla Public License
  6. // v. 2.0. If a copy of the MPL was not distributed with this file, You can
  7. // obtain one at http://mozilla.org/MPL/2.0/.
  8. #ifndef IGL_MIN_HEAP_H
  9. #define IGL_MIN_HEAP_H
  10. #include <queue>
  11. #include <vector>
  12. #include <functional>
  13. namespace igl
  14. {
  15. /// Templated min heap (reverses sort order of std::priority_queue)
  16. /// @tparam T type of elements in heap
  17. template<class T> using min_heap =
  18. std::priority_queue< T, std::vector<T >, std::greater<T > >;
  19. }
  20. #endif