检查向量中的一组值



我有一组数字:

{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;
}

相关内容

  • 没有找到相关文章

最新更新