为什么sort()函数用于一组类对象时会导致编译错误
Why sort() function causes compilation error when it is used for set of class objects
我尝试为类重载<
操作符,并按如下方式调用函数:
bool Edge::operator<(Edge const & e) const {
return this->GetCost() < e.GetCost();
}
main () sort(edge_set.begin(),edge_set.end());
此外,我还尝试为在main.cpp中定义的对象编写一个简单的比较器函数,并试图调用sort()
,但再次失败:
bool edge_comparator(Edge& e1, Edge& e2){
return (e1.GetCost() < e2.GetCost());
}
main () sort(edge_set.begin(),edge_set.end(), edge_comparator);
我得到一个编译错误的那些我尝试。我哪里做错了?如何对对象集合进行排序?
std::set
是一个已排序的关联容器,因此不能重新排序。排序准则应用于构造和元素插入。
Edit:您有一组Edge
指针。如果您希望根据自己的标准对其进行排序,可以实例化一个std::set
,其类型为一个函子,该函子在一对Edge
指针之间执行小于比较,作为第二个模板参数:
struct EdgePtrCmp
{
bool operator()(const Edge* lhs, const Edge* rhs) const
{
return lhs->GetCost() < rhs->GetCost();
}
}
然后std::set<Edge*, EdgePtrCmp> s;
Edit 2:问题再次更改,因此不清楚是否处理一组指针
有两个问题。首先,不能对集合中的元素重新排序。它们的排序标准是在构造时确定的,它是物体的基本组成部分。这对于实现O(log n)次查找、插入和删除是必要的,这是std::set
承诺的一部分。默认情况下,它将使用std::less<Edge>
,它应该调用operator<
。但是你也可以使用edge_comparator
函数,像这样:
std::set<Edge, bool(*)(Edge&,Edge&)> edge_set(edge_comparator);
第二,std::sort
只能在随机访问迭代器或更好的迭代器上使用,std::set
迭代器是双向的。
相关文章:
- std::is_base_of表示ctor编译错误
- Qt5:使用QCommandLineParser类时出现奇怪的编译错误
- 如何修复sfml c++代码编译错误
- 使用 MATLAB 编码器生成C++代码:编译错误"undefined reference to `rgb2gray_tbb_real64'"
- 使用外部SDK工具链文件在VisualStudio上生成项目编译错误
- vscode下的Arduino代码出现意外编译错误
- 第三方 API 中的编译错误 - Visual Studio
- std::cout输出int时出现编译错误
- 奇怪的代码抛出编译错误模板< J,int aSize=10> C2143:语法错误:在"<"之前缺少";"
- 提升图广度优先搜索前置编译错误
- C++ 中的编译错误:未定义对"主"的引用 collect2:错误:ld 返回 1 个退出状态
- 使用带有 ref 参数的成员函数创建线程时出现编译错误
- 我在C++中遇到了这个奇怪的编译错误
- 在C++中使用 Catch 测试框架编译错误"error: expected ';' at end of declaration list"
- 使用 std::enable_if 限制派生类的模板参数时出现编译错误
- 现代OpenGL和GLEW Libraray的编译错误
- C++ 编译错误:意外的类型名称"字符串":预期的表达式
- C ++程序编译错误,找不到/访问文件
- 使用直接大括号初始化时,C++ 编译错误"声明末尾的预期";"
- 为什么传递非静态成员函数会导致编译错误?