簡體   English   中英

priority_queue 第二個參數:容器對象

[英]priority_queue second parameter :Container object

我知道 priority_queue 的第二個參數是一個容器(默認情況下它是一個vector )。 但是如果我想使用queuelist作為底層容器怎么辦?

struct compare {
    bool operator()(int&a,int&b) {
        return a > b;
    }
};

int main(int argc, char** argv) {
    std::priority_queue<int, queue<int> , compare >pq();
    return 0;
}

當我使用pq.push()時它不起作用。
那么priority_queue必須使用vector作為容器嗎? 或者我如何改用隊列?

我非常感謝你的幫助。 非常感謝。

從這個參考

Container - 用於存儲元素的底層容器的類型。 容器必須滿足SequenceContainer的要求,其迭代器必須滿足 RandomAccessIterator 的要求。 此外,它必須提供以下具有通常語義的函數:

  • 正面()
  • 推回()
  • pop_back()

標准容器std::vectorstd::deque滿足這些要求。

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM