阅读量:0
std::copy_if
是 C++ 标准库中的一个算法,它用于从一个输入范围复制满足特定条件的元素到另一个输出范围。其基本语法如下:
template< class InputIt, class OutputIt, class UnaryPredicate > OutputIt copy_if( InputIt first, InputIt last, OutputIt d_first, UnaryPredicate p );
这里,InputIt
和 OutputIt
是迭代器类型,表示输入和输出范围;UnaryPredicate
是一个一元谓词,即接受单个参数的函数或函数对象,用于定义复制条件。
下面是一个使用 std::copy_if
的示例,将一个 std::vector
中所有大于 5 的元素复制到另一个 std::vector
中:
#include <iostream> #include <vector> #include <algorithm> #include <iterator> int main() { std::vector<int> src = {1, 6, 3, 8, 2, 10}; std::vector<int> dest; // 预分配足够的空间以提高性能 dest.reserve(src.size()); // 使用 std::copy_if 复制大于 5 的元素 std::copy_if(src.begin(), src.end(), std::back_inserter(dest), [](int x) { return x > 5; }); // 输出结果 for (int num : dest) { std::cout << num << ' '; } return 0; }
在这个示例中,我们使用了 lambda 表达式 [](int x) { return x > 5; }
作为谓词,它定义了复制条件为“元素值大于 5”。std::back_inserter(dest)
用于将复制的元素插入到 dest
的末尾。注意,我们还使用了 dest.reserve()
来预分配足够的空间以提高性能,因为 std::back_inserter
会导致多次内存分配。