我有两个载体。
vector<Object> objects;
vector<string> names;
这两个向量已填充并具有相同的大小。 我需要一些算法来分配对象变量。它可以使用boost :: lambda。 让我们说:
some_algoritm(objects.begin(), objects.end(), names.begin(), bind(&Object::Name, _1) = _2);
有什么建议吗?
答案 0 :(得分:5)
我认为您需要std::for_each
,因为每个Object
实例都在就地修改:
std::vector<std::string>::const_iterator names_it = static_cast<const std::vector<std::string>&>(names).begin();
std::for_each(objects.begin(), objects.end(),
boost::lambda::bind(&Object::Name, boost::lambda::_1) = *boost::lambda::var(names_it)++);
这是一个完整的,可编辑的例子:
#include <algorithm>
#include <cstdlib>
#include <iostream>
#include <string>
#include <vector>
#include <boost/lambda/bind.hpp>
#include <boost/lambda/lambda.hpp>
class Object
{
public:
std::string Name;
Object(const std::string& Name_ = "")
: Name(Name_)
{
}
};
int main()
{
std::vector<Object> objects(3, Object());
std::vector<std::string> names;
names.push_back("Alpha");
names.push_back("Beta");
names.push_back("Gamma");
std::vector<std::string>::const_iterator names_it = static_cast<const std::vector<std::string>&>(names).begin();
std::for_each(objects.begin(), objects.end(), boost::lambda::bind(&Object::Name, boost::lambda::_1) = *boost::lambda::var(names_it)++);
std::vector<Object>::iterator it, end = objects.end();
for (it = objects.begin(); it != end; ++it) {
std::cout << it->Name << std::endl;
}
return EXIT_SUCCESS;
}
输出:
Alpha Beta Gamma
答案 1 :(得分:3)
我想不出一个std::
算法。但是,你总是可以写自己的:
template < class It1, class It2, class Operator >
It2 zip_for_each ( It1 first1, It1 last1,
It2 result, Operator op )
{
while (first1 != last1)
op(*first++, *result++);
return result;
}
<小时/> 编辑:另一种选择,如果您能够恰当地定义
operator=
,则为std::copy
:
#include <vector>
#include <string>
struct Object {
std::string name;
int i;
void operator=(const std::string& str) { name = str; }
};
int main () {
std::vector<Object> objects(3);
std::vector<std::string> names(3);
names[0] = "Able";
names[1] = "Baker";
names[2] = "Charlie";
std::copy(names.begin(), names.end(), objects.begin());
}