Я пытаюсь создать vector<Wrap>
с теми же значениями, что и в v
, Я попробовал следующие комбинации, не сработало!
using namespace std;
struct Wrap
{
int data;
//Other members
};
int main()
{
int a[10] = {2345,6345,3,243,24,234};
vector<int> v(&a[0],&a[10]);
Wrap w;
//Populate other members of w
vector<Wrap> vw;
using namespace boost::lambda;
//transform(v.begin(),v.end(), back_inserter(vw), (bind(&Wrap::data,&w,_1), boost::lambda::constant(w)));
//transform(v.begin(),v.end(), back_inserter(vw), bind(&Wrap::data,&w,_1), boost::lambda::constant(w));
//transform(v.begin(),v.end(), back_inserter(vw), ((w.data = _1), boost::lambda::constant(w)));
//transform(v.begin(),v.end(), back_inserter(vw), ((w.data = _1), w));
cout << vw.size() << endl;
BOOST_FOREACH(Wrap w, vw)
{
cout << w.data << endl;
}
}
Замечания: Пока не могу использовать C ++ 11
Обновить Любое чистое решение, которое работает в C ++ 03, прекрасно. Не нужно использовать буст-лямбду
использование std::transform()
и укажите двоичную функцию операции. Например:
#include <iostream>
#include <vector>
#include <algorithm>
struct Wrap
{
int data;
};
Wrap set_data(int a_new_data, Wrap a_wrap)
{
a_wrap.data = a_new_data;
return a_wrap;
}
int main()
{
int a[10] = { 2345, 6345, 3, 243, 24, 234 };
const size_t A_SIZE = sizeof(a) / sizeof(a[0]);
std::vector<Wrap> vw(A_SIZE);
std::transform(a, a + A_SIZE, vw.begin(), vw.begin(), set_data);
std::cout << vw[0].data << ','
<< vw[1].data << ','
<< vw[5].data << ','
<< vw[9].data << '\n';
return 0;
}
Посмотреть демо на http://ideone.com/DHAXWs .
Вы должны определить конструктор для Wrap
:
struct Wrap
{
Wrap(int data): data(data) {}
int data;
};
И тогда вы можете просто сделать это:
transform(v.begin(),v.end(), back_inserter(vw), constructor<Wrap>());
constructor
происходит от boost/lambda/construct.hpp
и он оборачивает конструктор как объект функции.