微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

集合中的比较器如何与 C++ 中的函子一起工作?

如何解决集合中的比较器如何与 C++ 中的函子一起工作?

这是一个简单的程序来表明我的观点:

#include <iostream>
#include <set>
class comparator
{
public:
  bool operator()(int* a,int* b){return *a < *b;}
};
int main()
{
  std::set<int*> v1{new int{1},new int{1},new int{2},new int{2}};
  std::set<int*,comparator> v2{new int{1},new int{2}};
  std::cout << v1.size() << std::endl; // 4
  std::cout << v2.size() << std::endl; // 2
  return 0;
}

在使用函子之前,集合通过整数地址删除重复元素。但是,在包含函子之后,它会根据值进行删除。问题是在函子中我没有定义操作符在重复值上返回 true,那么为什么它会显示这种行为?

解决方法

我没有定义在重复值上返回 true 的运算符,为什么它会显示这种行为?

因为 std::set 旨在与“小于”比较器一起使用,并且它以这种方式实现。也就是说,如果对于集合中的两个值 xyx<yy<x 都为假,则假定 xy相等,因此它们是重复的。

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。