другой алгоритм копирования - PullRequest
9 голосов
/ 06 октября 2011

У меня есть два вектора.

vector<Object> objects;
vector<string> names;

Эти два вектора заполнены и имеют одинаковый размер. Мне нужен некоторый алгоритм, который делает присваивание переменной объекта. Это может быть использование boost :: lambda. Допустим,

some_algoritm(objects.begin(), objects.end(), names.begin(), bind(&Object::Name, _1) = _2);

Есть предложения?

Ответы [ 2 ]

5 голосов
/ 06 октября 2011

Я думаю, что вы хотите 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
3 голосов
/ 06 октября 2011

Я не могу придумать алгоритм 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());
}
...