filt
是一个 C++ 标准库中的函数,用于对容器(如数组、向量等)中的元素进行过滤
filt
函数的原型如下:
template< class InputIt, class OutputIt, class UnaryPredicate >
OutputIt filt( InputIt first, InputIt last, OutputIt d_first, UnaryPredicate p );
参数说明:
InputIt first
和 InputIt last
:输入范围的起始和结束迭代器。OutputIt d_first
:输出范围的起始迭代器。UnaryPredicate p
:一个一元谓词,用于确定哪些元素应该被保留在输出范围中。filt
函数将遍历输入范围内的所有元素,并使用一元谓词 p
来判断每个元素是否应该被保留。如果 p
返回 true
,则该元素将被复制到输出范围中;否则,该元素将被忽略。
下面是一个简单的示例,展示了如何使用 filt
函数过滤一个整数向量中的偶数:
#include<iostream>
#include<vector>
#include<algorithm>
#include<iterator>
int main() {
std::vector<int> input = {1, 2, 3, 4, 5, 6, 7, 8, 9, 10};
std::vector<int> output;
// 使用 lambda 表达式定义一个一元谓词,用于判断一个整数是否为偶数
auto is_even = [](int x) { return x % 2 == 0; };
// 使用 filt 函数过滤输入向量中的偶数
std::filt(input.begin(), input.end(), std::back_inserter(output), is_even);
// 输出过滤后的结果
for (int num : output) {
std::cout<< num << " ";
}
return 0;
}
输出结果:
2 4 6 8 10
需要注意的是,filt
函数并不是 C++ 标准库中的一部分,而是一个自定义函数。在实际编程中,你可以使用 std::copy_if
函数实现类似的功能。