用set、map等存储自定义结构体时容器内部判别各元素是否相同的注意事项
STL作为通用模板极大地方便了C++使用者的编程,因为它可以存储任意数据类型的元素
如果我们想用set与map来存储自定义结构体时,如下
struct pp
{
double xx;
double yy;
};
set<pp> st;
struct ab
{
double aa;
double bb;
double cc;
};
map<ab, int> mm;
上面我们使用 set 来存储 pp结构体,将 ab结构体作为一个映射的Key
显然我们这样做编译器会报错,原因是set与map内部需要比较各个元素的大小,这样我们的结构体缺失了小于号的重载,无法存储
改后如下:
struct pp
{
double xx;
double yy;
bool

当使用set、map等STL容器存储自定义结构体时,需要重载小于号运算符以判断元素是否相同。仅比较部分成员可能导致相同元素误判,如两个结构体的部分字段相同。正确做法是全面比较所有成员,确保不同元素返回的比较值不相等,避免去重问题。
最低0.47元/天 解锁文章
854

被折叠的 条评论
为什么被折叠?



