STL set 集合里面不能放结构体么?
#include<iostream>
#include<set>
using namespace std;
struct A{
string str;
int score;
};
void test(){
set<A>s;
A a,b,c;
a.str="shanying";a.score=100;
b.str="shanying";b.score=0;
c.str="baitoudiao";c.score=50;
s.insert(a);
/*s.insert(b);
s.insert(c);*/
cout<<s.size()<<endl;
}
像上面这代码,插入的时候就出错了,其他的暂时没发现错误。于是乎,set的元素不能为结构体么?
[解决办法]
肯定可以,C++的设计哲学之一就是使得程序在对待自定义类型时和内置类型必须是一致的(甚至自定义类型的支持更好)。所以,肯定是你程序的问题,如下:
《C++标准程序库》中明确指出:“只要是assignable、copyable、comparable(根据某个排序准则)的型别T,都可以成为set或multiset的元素型别。”。其中,所谓的comparable指的是less,即可进行<比较。
反之,则不被支持,所以,问题是,你的A是否支持上述三种语义?
看下面的测试代码:
void test(){
set<A>s;
A a,b,c;
a.str="shanying";a.score=100;
b.str="shanying";b.score=0;
c.str="baitoudiao";c.score=50;
A cpy(a);
cout<<"orign:"<<a.str<<','<<a.score<<endl;
cout<<"copy:"<<cpy.str<<','<<cpy.score<<endl;
A assigned;
assigned = a;
cout<<"assigned:"<<assigned.str<<','<<assigned.score<<endl;
// cout<<"a<b?"<<(a<b?"true":"false")<<endl; 无法通过编译
}
#include <iostream>
#include <string>
#include <set>
using namespace std;
struct A{
string str;
int score;
};
bool operator<(const A& lhs, const A& rhs) {
return lhs.score<rhs.score;
}
void test(){
set<A>s;
A a,b,c;
a.str="shanying";a.score=100;
b.str="shanying";b.score=0;
c.str="baitoudiao";c.score=50;
A cpy(a);
cout<<"orign:"<<a.str<<','<<a.score<<endl;
cout<<"copy:"<<cpy.str<<','<<cpy.score<<endl;
A assigned;
assigned = a;
cout<<"assigned:"<<assigned.str<<','<<assigned.score<<endl;
cout<<"a<b?"<<(a<b?"true":"false")<<endl;
s.insert(a);
s.insert(b);
s.insert(c);
cout<<"size:"<<s.size()<<endl;
}
int main() {
test();
return 0;
}