我正在尝试使用与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的干净解决方案都可以。不需要使用boost lambda
答案 0 :(得分:1)
您应该为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
,它将构造函数包装为函数对象。
答案 1 :(得分:1)
使用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上的演示。