我写了那几行:
#include <vector>
#include <algorithm>
#include <stdlib.h>
#include <time.h>
using namespace std;
template <class T> struct First
{
T num;
First() {}
First(const T &a) : num(a) {}
};
template <typename var> bool criterio(First<var> &primo, First<var> &secondo)
{
return (primo.num < secondo.num);
}
int main()
{
vector< First<int> > f;
srand (time(NULL));
for(int i=0; i<20; i++) f.push_back( First<int>(rand() % 20) );
sort(f.begin(),f.end(),criterio);
return 0;
}
我用“g++ program2.C”编译,答案是:
program2.C: 在函数‘int main()’中:
program2.C:28: error: no matching function for call to‘sort(__gnu_cxx::__normal_iterator*, std::vector, std::allocator > > > , __gnu_cxx::__normal_iterator*, std::vector, std::allocator > > >, unresolved overloaded function type)’
我不知道这是什么问题...你能帮我吗??
感谢帮助...
最佳答案
criterio 是一个模板,所以你需要给出模板化的类型:
sort(f.begin(),f.end(),criterio<int>)
并且 criterio 函数必须将 const 引用作为参数:
template <typename var> bool criterio(const First<var> &primo,
const First<var> &secondo)
{
return (primo.num < secondo.num);
}
关于c++ - STL算法中排序函数的问题,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/2172723/