C++ 算法 copy_if() 函数用于将容器 [first,last] 的元素从 pred 值为 true 的结果开始复制到不同的容器中。
用法
template<class InputIterator, class OutputIterator, class UnaryPredicate>
OutputIterator copy_if(InputIterator first, InputIterator last, OutputIterator result,UnaryPredicate pred);
参数
first:它是范围的第一个元素的输入迭代器,其中元素本身包含在范围内。
last: 它是范围最后一个元素的输入迭代器,其中元素本身不包含在范围内。
result:它是复制元素的新容器的第一个元素的输出迭代器。
pred:它是一个一元函数,它接受一个元素作为参数并检查指定的条件。
返回值
返回以结果开始的新范围的最后一个元素的迭代器。
例子1
#include<iostream>
#include<algorithm>
#include<vector>
int main()
{
std::vector<int> a = {20,10, 4,-4,-10};
std::vector<int> b (a.size());
auto ti = std::copy_if(a.begin(),a.end(),b.begin(),[](int j){ return !(j<0);});
b.resize(std::distance(b.begin(),ti));
std::cout<<"b contains:";
for (int& x:b) std::cout<<" "<<x;
std::cout<<"\n";
return 0;
}
输出:
b contains:20 10 4
例子2
#include<iostream>
#include<algorithm>
#include<vector>
using namespace std;
int main()
{
vector<int> u1={2,6,7,4,9,4};
vector<int> u2(6);
copy_if(u1.begin(), u1.end(), u2.begin(), [](int j){return j%2!=0;});
cout<<"The new vector using copy_if contains:";
for(int k=0; k<u2.size(); k++)
cout<<u2[k]<<" ";
}
输出:
The new vector using copy_if contains:7 9 0 0 0 0
复杂度
函数的复杂度从第一个元素到最后一个元素是线性的。
数据竞争
访问部分或全部容器对象。
异常
如果任何容器元素抛出一个异常,该函数就会抛出异常。
相关用法
- C++ copy_n()用法及代码示例
- C++ copy_backward()用法及代码示例
- C++ copy()用法及代码示例
- C++ copysign()用法及代码示例
- C++ count()用法及代码示例
- C++ complex cosh()用法及代码示例
- C++ count_if()用法及代码示例
- C++ conj()用法及代码示例
- C++ cosh()用法及代码示例
- C++ cos()用法及代码示例
- C++ complex cos()用法及代码示例
- C++ clock()用法及代码示例
- C++ cbrt()用法及代码示例
- C++ c32rtomb()用法及代码示例
- C++ c16rtomb()用法及代码示例
- C++ ctime()用法及代码示例
- C++ cin get()用法及代码示例
- C++ ceil()用法及代码示例
- C++ cauchy_distribution a()用法及代码示例
- C++ unordered_map cbegin用法及代码示例
注:本文由纯净天空筛选整理自 C++ Algorithm Function copy_if()。非经特殊声明,原始代码版权归原作者所有,本译文未经允许或授权,请勿转载或复制。