我想做一個優先級隊列,其中最頂部的元素包含最小的整數。我做了一個比較功能對象。一切都很順利,但是,每當我試圖打印出最上面的元素std::cout<<pq.top<<std::endl
我得到一個錯誤,指出:C++編程候選函數不可行
candidate function not viable: no known conversion from 'const value_type' (aka 'const Foo') to
'const void *' for 1st argument; take the address of the argument with &
basic_ostream& operator<<(const void* __p);
我真的很新的節目的話,我真的不知道該怎麼辦。
#include<iostream>
#include<queue>
#include <vector>
class Foo
{
public:
int data;
Foo(int data): data(data) {}
};
class Compare
{
public:
int operator() (Foo dat1, Foo dat2)
{
if(dat1.data < dat2.data)
return dat1.data;
else return dat2.data;
}
};
int main()
{
std::priority_queue<Foo, std::vector<Foo>, Compare> pq;
pq.push(5);
pq.push(7);
pq.push(1);
pq.push(2);
pq.push(3);
std::cout << pq.top() << std::endl;
return 0;
}
你似乎錯過了句子的結尾「但是當我嘗試..:」會發生什麼?問題是什麼? –