我有一段这样的代码:
set<string>::iterator it1;
set<string>::iterator it2;
pair<set<string>::iterator,bool> ret;
set<string> s;
ret = s.insert("bbbb1");
it1 = ret.first;
ret = s.insert("bbbb2");
it2 = ret.first;
map<set<string>::iterator, set<string>::iterator> m;
m.insert(make_pair(it1,it2));
但是最后一行“m.insert(make_pair(it1,it2));”失败..
答案 0 :(得分:8)
std::set
迭代器不是随机访问迭代器,因此它们不会低于可比性。
您在std::map
中用作关键字的类型必须能够使用strict weak ordering进行排序。默认情况下,std::map
使用<
来订购密钥。您可以通过在定义std::map
的类型时提供比较器来更改此行为。您可能希望使用迭代器指向的对象执行某些关系比较。