因为插入的类型是自定义的,不是基本类型(基本类型有默认的排序准则),因此需要重载 < 运算符。(相当于给自定义类型一个排序准则)。
e.g. :
#include<iostream>
#include<set>
using namespace std;
struct aa{
int b;
friend bool operator < (const aa& n1, const aa& n2)
{
return n1. b < n2. b;
}
};
int main()
{
aa y;
y.b = 1;
set<aa> uu;
uu.insert(y);
set<aa>::iterator it = uu.begin();
cout<<(*it).b<<endl;
return 0;
}
本文介绍如何为自定义类型重载小于运算符以实现排序。通过一个具体的C++示例展示了如何定义比较运算符来满足标准容器如set的排序需求。
1657





