如果有向量,我们需要找到具有相同条件的多个项目。
如果我们调用std::find_if
,它将返回条件的第一次出现。
std::vector <int> List{0,1,2,3,4,5,6};
auto item = find_if(List.begin(), List.end(), [](int x)
{
return x > 2;
}
);
我知道我们可以使用std::for_each
并将条件和操作放在lambda表达式中,但我问是否有一个方法可以自己完成并返回找到的项目的向量。
答案 0 :(得分:8)
您可以使用std::copy_if
使用满足谓词的项目的副本填充向量。
#include <vector> // vector
#include <iterator> // copy_if
#include <algorithm> // back_inserter
int main()
{
std::vector<int> List{0,1,2,3,4,5,6};
std::vector<int> good_items;
std::copy_if(List.begin(), List.end(), std::back_inserter(good_items),
[](int x) { return x > 2; });
}
答案 1 :(得分:2)
std::copy_if
与std::back_inserter
一起应该可以解决问题