将对象插入到std :: set中的关键是什么?至于下面的例子,我将类Classcomp的对象插入到std :: set中。但是,我想查找Classcomp的对象是否具有特定的' id = 1'是否存在于std :: set中?
#include <iostream>
#include <set>
struct Classcomp {
int val = 0;
int id = 0; ///ID for the object
bool operator() (const Classcomp& lhs, const Classcomp& rhs) const
{return lhs.val<rhs.val;}
};
int main ()
{
Classcomp c1,c2,c3,c4;
c1.val = 92;c1.id = 2;
c2.val = 94;c2.id = 3;
c3.val = 10;c3.id = 1;
std::set<Classcomp,Classcomp> fifth; // class as Compare
fifth.insert(c1);fifth.insert(c2);fifth.insert(c3);
for (auto x: fifth) {std::cout << x.id << " " << x.val << std::endl;}
if (fifth.find()) {std::cout << "Got it";} //What should I pass as arguments to fifth.find()?
return 0;
}
答案 0 :(得分:4)
集合与地图的不同之处在于集合中对象的值是键。如果您需要将键与值分开,则需要一个键值容器,例如std::map
或std::unordered_map
。
<强>澄清强>
我不是在讨论简单地迭代集合中的所有对象并检查每个对象是否具有指定密钥的选项 - 这可以通过std::find
轻松完成。如果那是你想要的,请澄清。
答案 1 :(得分:1)
由于您的课程按字段val
排序,因此您有以下选项:
std::find
或std::find_if
boost::multiindex
并按val
创建索引以及id