조건부 복사 (1.로 수행 가능)를 수행하고 copy_if
싶지만 값 컨테이너에서 해당 값에 대한 포인터 컨테이너 (2. 로 수행 가능) 로의 사용 사례가 나타났습니다 transform
.
사용 가능한 도구로 는 두 단계 미만으로 수행 할 수 없습니다 .
#include <vector>
#include <algorithm>
using namespace std;
struct ha {
int i;
explicit ha(int a) : i(a) {}
};
int main()
{
vector<ha> v{ ha{1}, ha{7}, ha{1} }; // initial vector
// GOAL : make a vector of pointers to elements with i < 2
vector<ha*> ph; // target vector
vector<ha*> pv; // temporary vector
// 1.
transform(v.begin(), v.end(), back_inserter(pv),
[](ha &arg) { return &arg; });
// 2.
copy_if(pv.begin(), pv.end(), back_inserter(ph),
[](ha *parg) { return parg->i < 2; }); // 2.
return 0;
}
우리가 부를 수있는 당연히 remove_if
에 pv
임시의 필요성을 제거, 더 나은 아직하지만, 그것은 할 어렵지 않다 구현 이 같은 (단항 작업) :
template <
class InputIterator, class OutputIterator,
class UnaryOperator, class Pred
>
OutputIterator transform_if(InputIterator first1, InputIterator last1,
OutputIterator result, UnaryOperator op, Pred pred)
{
while (first1 != last1)
{
if (pred(*first1)) {
*result = op(*first1);
++result;
}
++first1;
}
return result;
}
// example call
transform_if(v.begin(), v.end(), back_inserter(ph),
[](ha &arg) { return &arg; }, // 1.
[](ha &arg) { return arg.i < 2; });// 2.
- 사용 가능한 C ++ 표준 라이브러리 도구에 대한보다 우아한 해결 방법이 있습니까?
transform_if
도서관에 존재하지 않는 이유 가 있나요? 기존 도구의 조합이 충분한 해결 방법이고 / 또는 성능이 현명한 것으로 간주됩니까?
transform_if
은 "특정 술어가 충족되는 경우에만 변환"을 의미합니다. 당신이 원하는 것에 대한 더 설명적인 이름이 될 것입니다copy_if_and_transform
!