簡體   English   中英

如何預分配(保留)一個priority_queue<vector> ?

[英]How to preallocate(reserve) a priority_queue<vector>?

如何使用std::vector類型的容器預分配std::priority_queue

std::priority_queue<unsigned char, std::vector<unsigned char>> pq;
pq.c.reserve(1024);

不編譯,因為底層向量是受保護的成員。 是否可以使用priority_queue的構造函數將其包裝在預先保留的向量周圍?

是的,有一個構造函數 您還必須指定一個比較器,這有點乏味:

std::vector<unsigned char> container;
container.reserve(1024);
std::priority_queue<unsigned char, std::vector<unsigned char>> pq (
    std::less<unsigned char>(), std::move(container));

您也可以使用邪惡的惡作劇來訪問受保護的成員,但我不建議這樣做。

另一種解決方案可能是使您自己的類從 std::priority_queue 派生,例如:

class MyPQueue : public std::priority_queue<unsigned char, std::vector<unsigned char>>
{
public:
    MyPQueue(size_t reserve_size)
    {
        this->c.reserve(reserve_size);
    }
};

然后,在代碼中,以這種方式創建一個 MyPQueue 對象:

MyPQueue mpq(1024);

哪個對象可以在需要時向上轉換回基類。

std::priority_queue<unsigned char, std::vector<unsigned char>>& pq = mpq;

通常,使用C++11您可以編寫如下的make_reserved函數。

#include <vector>
#include <iostream>
#include <utility>
#include <functional>

template <class T>
std::vector<T> make_reserved(const std::size_t n)
{
  std::vector<T> v;
  v.reserve(n);
  return v;
}

int main()
{
  using Q = std::priority_queue<int, std::vector<int>>;
  auto q = Q(std::less<int>(), make_reserved<int>(100));
  std::cout << q.size() << std::endl;
}

我沒有足夠的聲譽來評論 Mike Seymour 的帖子,但他省略了std::priority_queue的第三個模板參數:

std::vector<unsigned char> container;
container.reserve(1024);
std::priority_queue<unsigned char, std::vector<unsigned char>, std::less<unsigned char>> pq(std::less<unsigned char>(), std::move(container));

它確實很冗長,但它確實有效。

暫無
暫無

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

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