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#include #include #include int main() { std::vector input = {1, 2, 3, 4, 5, 6, 7, 8, 9, 10}; std::vector 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
函数实现类似的功能。