我有一组数字:
{2, 6, 8}
我想检查这些数字中的任何一个是否在我的向量中:
std::vector<int> myVector;
我知道我可以使用算法的 std::find 单独检查每个:
auto iter1 = std::find(myVector.begin(), myVector.end(), 2);
auto iter2 = std::find(myVector.begin(), myVector.end(), 6);
auto iter3 = std::find(myVector.begin(), myVector.end(), 8);
if(iter1 != myVector.end() || iter2 != myVector.end() || iter3 != myVector.end())
std::cout << "A desired value was found in the vector!"
在这个例子中,只有三个数字,但真正的数字集会更大。另外,这似乎有点乏味。有没有更好的解决方案?
您可以使用
std::find_first_of
:
std::vector<int> myVector = /* something */;
std::vector<int> values = {2, 6, 8};
auto first_found = std::find_first_of(std::begin(myVector), std::end(myVector),
std::begin(values), std::end(values));
if (first_found != std::end(myVector)) {
// Found one of them!
}
如果要
检查"集合"中是否包含数字,请使用std::set
std::set<int> myset = {3,4,6,34,2,6,78,8,5,0};
if (myset.count(5) > 0) {
std::cout << "Hooray!" << std::endl;
}