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
函數實現類似的功能。