名前空間
変種
操作

std::priority_queue に対する推定ガイド

提供: cppreference.com
ヘッダ <queue> で定義
template <class Compare, class Container>

priority_queue(Compare, Container)

 -> priority_queue<typename Container::value_type, Container, Compare>;
(1) (C++17以上)
template<class InputIt,

         class Comp = std::less<typename std::iterator_traits<InputIt>::value_type>,
         class Container = std::vector<typename iterator_traits<InputIt>::value_type>>
priority_queue(InputIt, InputIt, Comp = Comp(), Container = Container())

  -> priority_queue<typename std::iterator_traits<InputIt>::value_type, Container, Comp>;
(2) (C++17以上)
template<class Comp, class Container, class Alloc>

priority_queue(Comp, Container, Alloc)

  -> priority_queue<typename Container::value_type, Container, Comp>;
(2) (C++17以上)

基になるコンテナ型 (オーバーロード (1,3)) およびイテレータ範囲 (オーバーロード (2)) からの推定を可能とするため、これらの推定ガイドstd::priority_queue に対して提供されます。 このオーバーロードは、InputItLegacyInputIterator を満たし、 AllocAllocator を満たし、 CompAllocator を満たさず、 ContainerAllocator を満たさず、さらに (3) に対しては std::uses_allocator_v<Container, Alloc>true である場合にのみ、オーバーロード解決に参加します。

ノート: ある型が LegacyInputIterator を満たさないとライブラリが判断する範囲は、少なくとも整数型が入力イテレータとして適合しないことを除いて、未規定です。 同様に、ある型が Allocator を満たさないと判断される範囲も、少なくともメンバ型 Alloc::value_type が存在しなければならず、式 std::declval<Alloc&>().allocate(std::size_t{}) が評価されない被演算子として扱われたときに well-formed でなければならないことを除いて、未規定です。

[編集]

#include <vector>
#include <queue>
int main() {
   std::vector<int> v = {1,2,3,4};
   std::priority_queue pq1{v};                  // deduces std::priority_queue<int>
   std::priority_queue pq2{v.begin(), v.end()}; // deduces std::priority_queue<int>
}