[iterator] transform_iterator
data:image/s3,"s3://crabby-images/68a92/68a92ef5f9509ed861931148198f5863404947f6" alt=""
Hello
I just came across transform_iterator and found it a useful generic tool.
But is it possible for it to go further to make the following code get
compiled and run as expected?
struct A
{
int i_;
A() : i_(0) {}
explicit A(int i) : i_(i) {}
};
const int N = 5;
A a_list[N] = { A(-3), A(1), A(3), A(2), A(-4) };
typedef boost::function
data:image/s3,"s3://crabby-images/48064/48064d72b0cc2a7ace5789b3da09cb4b9f086523" alt=""
AMDG Max wrote:
I just came across transform_iterator and found it a useful generic tool. But is it possible for it to go further to make the following code get compiled and run as expected?
No.
struct A { int i_; A() : i_(0) {} explicit A(int i) : i_(i) {} };
const int N = 5; A a_list[N] = { A(-3), A(1), A(3), A(2), A(-4) };
typedef boost::function
fn_t; // sorting a_list according to the elements' i_ member std::stable_sort(boost::make_transform_iterator(a_list, fn_t(boost::bind(&A::i_, _1))), boost::make_transform_iterator(a_list+N, fn_t(boost::bind(&A::i_, _1))), std::less<int>());
stable_sort assumes that the sort keys are the same as the objects that it is moving around. In Christ, Steven Watanabe
participants (2)
-
Max
-
Steven Watanabe