具有自定义比较功能的 C++ 优先级队列在 Push() 上的行为不正确
C++ Priority Queue with Custom Compare Function not Behaving Correctly on Push()
我定义了一个像这样的 C++ 优先级队列:
priority_queue<pair<int,int>, vector<pair<int,int>>, decltype(&mygreater)> frontier(&mygreater);
使用像这样的自定义 mygreater function():
bool mygreater(pair<int,int> v1, pair<int,int> v2) {
return v1.first > v2.first;
}
然而,当我尝试将整数对的向量推送到优先级队列时,我不断收到大量错误,包括:
error: no matching function for call to ‘std::priority_queue<std::pair<int, int>, std::vector<std::pair<int, int> >, bool (*)(std::pair<int, int>, std::pair<int, int>)>::push(std::vector<std::pair<int, int> >&)’ frontier.push(temp);
可能有人知道是什么导致我尝试推送到优先级队列时出错?任何帮助是极大的赞赏。
此错误与您的自定义比较无关。如果你这样做,你会得到同样的错误:
std::priority_queue<int> q;
std::vector<int> v;
q.push(v);
std::priority_queue::push
接受您存储的任何类型的单个对象,而不是它们的整个向量。您正在存储的类型是 pair<int,int>
,但您正试图推送 vector<pair<int,int>>
。
我定义了一个像这样的 C++ 优先级队列:
priority_queue<pair<int,int>, vector<pair<int,int>>, decltype(&mygreater)> frontier(&mygreater);
使用像这样的自定义 mygreater function():
bool mygreater(pair<int,int> v1, pair<int,int> v2) {
return v1.first > v2.first;
}
然而,当我尝试将整数对的向量推送到优先级队列时,我不断收到大量错误,包括:
error: no matching function for call to ‘std::priority_queue<std::pair<int, int>, std::vector<std::pair<int, int> >, bool (*)(std::pair<int, int>, std::pair<int, int>)>::push(std::vector<std::pair<int, int> >&)’ frontier.push(temp);
可能有人知道是什么导致我尝试推送到优先级队列时出错?任何帮助是极大的赞赏。
此错误与您的自定义比较无关。如果你这样做,你会得到同样的错误:
std::priority_queue<int> q;
std::vector<int> v;
q.push(v);
std::priority_queue::push
接受您存储的任何类型的单个对象,而不是它们的整个向量。您正在存储的类型是 pair<int,int>
,但您正试图推送 vector<pair<int,int>>
。