Автоматизация между контейнерами разных объектов с назначением копирования

У меня есть разреженный вектор типа std::vector<SparseElement<T,I>>, где SparseElement:

template<typename T, typename I = unsigned int>
struct SparseElement
{
    I index;
    T value;
    //............
    SparseElement &operator=(const std::pair<I,T> &pair);
 }

Поскольку я использую для заполнения разреженного вектора std::map<I,T>, который имеет в качестве элементов std::pair<I,T>, мне нужно решение по этому вопросу без изменения членов "индекс" и "значение" SparseElement:

std::pair<I,T> a;
SparseElement<T,I> b;
b = a; // This is OK!
a = b; // Is there a solution on this problem?
// on containers:
std::vector<SparseElement<T,I>> vec;
std::map<I,T> m(vec.begin(), vec.end()); // Not working.
vec.assign(m.begin(), m.end()); // Working.

person Chameleon    schedule 21.03.2013    source источник
comment
a = b; возможно template<class I, class T> std::pair<I,T>& operator=(pair<I,T> lhs, SparseElement<T, I> const & SE); как бесплатную функцию.   -  person RedX    schedule 21.03.2013
comment
@RedX - нет, я тоже на это попался. operator= должна быть нестатической функцией-членом, определенной стандартом.   -  person Kiril Kirov    schedule 21.03.2013
comment
@KirilKirov Дэнг, было бы неплохо, если бы это было возможно.   -  person RedX    schedule 21.03.2013
comment
Затем, возможно, добавьте элемент преобразования operator std::pair<I,T>() в свой класс SparseElement.   -  person RedX    schedule 21.03.2013
comment
@RedX - хорошо, должно сработать.   -  person Kiril Kirov    schedule 21.03.2013


Ответы (1)


Переписывая ответ, чтобы помочь сообществу

template<typename T, typename I = unsigned int>
struct SparseElement
{
    //..........
    I index;                //!< Index of element in vector
    T value;                //!< Value of element
    //..........
    //! Template copy constructor from a different type of \p std::pair
    //! This is useful for conversion from MapVector to SparseVector
    template<typename T2, typename I2>
    SparseElement(const std::pair<I2,T2> &s) : index(s.first), value(s.second) {}
    //..........
    //! Template copy assign from a different type of \p std::pair
    //! This is useful for conversion from MapVector to SparseVector
    template<typename T2, typename I2>
    SparseElement &operator=(const std::pair<I2,T2> &s) { index = s.first; value = s.second; return *this; }

    //! Implicit conversion from SparseElement to a \p std::pair
    //! This is useful for conversion from SparseVector to MapVector
    operator std::pair<const I,T>() { return std::pair<const I,T>(index, value); }
};
person Chameleon    schedule 21.03.2013