我想在我的优先级队列中找到一个节点,但我找不到解决方案:( 如果你有解决方案,我很感兴趣。
寻求帮助。
答案 0 :(得分:6)
如果您确实需要搜索std::priority_queue
并希望有效地执行此操作,则可以派生新类并添加find
成员函数。由于您没有添加任何其他状态,因此std::priority_queue
不是多态的,因此您不必担心切片或其他问题。
#include <queue>
template<
class T,
class Container = std::vector<T>,
class Compare = std::less<typename Container::value_type>
> class MyQueue : public std::priority_queue<T, Container, Compare>
{
public:
typedef typename
std::priority_queue<
T,
Container,
Compare>::container_type::const_iterator const_iterator;
const_iterator find(const T&val) const
{
auto first = this->c.cbegin();
auto last = this->c.cend();
while (first!=last) {
if (*first==val) return first;
++first;
}
return last;
}
};
答案 1 :(得分:2)
如果您不关心性能,可以声明iterator
来遍历priority_queue的容器。但在C ++中,底层容器已声明为protected
,无法直接访问。
我获取容器迭代器的一个解决方案是声明一个继承自std::priority_queue
的新类。
typedef int Val_TYPE;
typedef vector<Val_TYPE> Container_TYPE;
typedef priority_queue<Val_TYPE, Container_TYPE> pri_queue;
class Queue: public pri_queue{
public:
Container_TYPE::iterator begin(){
return pri_queue::c.begin();
}
Container_TYPE::iterator end(){
return pri_queue::c.end();
}
}Q;
然后你可以得到容器的迭代器。
Q.push(4);
Q.push(3);
Q.push(35);
for(vector<int>::iterator p=Q.begin(); p!=Q.end(); p++)
cout << *p << endl;
为了提高效率,例如通过某些键查找数据,您可以使用pointers to data
。
假设班级Data
包含您的每个数据项。 Data.key
是搜索的关键,Data.value
是priority_queue
中的优先级。
struct Data{
VALUE_TYPE value;
KEY_TYPE key;
...
...
};
将所有数据存储在单独的集合中,例如数组或链接列表。
Data data[MAX];
定义一个新结构,用于存储某个data[i]
struct Node{
Data* data;
Node(Data* ptr){data=ptr;}
};
使用priority_queue
和其他数据结构支持搜索,即binary search tree
,hash
。在这里,我使用multimap
。
同时维护priority_queue
Node
和multimap
Node
。
struct cmp1{
bool operator(Node a, Node b){ return a.data->value < b.data->value; }
};
struct cmp2{
bool operator(Node a, Node b){ return a.data->key < b.data->key; }
};
priority_queue<Node, vector<Node>, cmp1> q;
multimap <KEY_TYPE, Node, cmp2> d;
for(int i = 0; i < n; ++i){
q.push(Node(&a[i]));
d.insert(a[i].key, Node(&a[i]));
}
然后,您可以使用multimap pointer
按键获取数据d
。使用priority_queue q
也可以满足对priority_queue的需求。
以上所有内容都只是使用指针。
答案 2 :(得分:-4)
我想你需要基本的帮助。读这可能这将有助于你
http://comsci.liu.edu/~jrodriguez/cs631sp08/c++priorityqueue.html