Jia*_*ong 0 c++ iterator stl key map
我有一段这样的代码:
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));
Run Code Online (Sandbox Code Playgroud)
但最后一行"m.insert(make_pair(it1,it2));" 失败..
std::set
迭代器不是随机访问迭代器,因此它们不低于可比性.
您在a中用作键的类型std::map
必须能够使用严格的弱排序进行排序.默认情况下,std::map
用于<
订购密钥.您可以通过在定义类型时提供比较器来更改此行为std::map
.您可能希望使用迭代器指向的对象执行某些关系比较.
归档时间: |
|
查看次数: |
587 次 |
最近记录: |