1

我有一组数字:

{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!"

在这个例子中,只有三个数字,但真正的数字集会更大。此外,这似乎有点乏味。有更好的解决方案吗?

4

2 回答 2

4

您可以使用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!
}
于 2012-11-13T18:34:46.080 回答
0

如果要检查一个数字是否包含在“集合”中,请使用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;
}
于 2012-11-13T18:34:20.063 回答