поддельные операции итератора для перечисления всех значений узла в графе

Я пытаюсь создать поддельный итератор для перечисления всех значений узлов в графе. Граф можно абстрагировать в любой последовательности, если последовательность состоит из всех и только узлов графа. Должен быть изменяемый квалификатор, а реализации 4 операций короткие и должны состоять только из 1 строки на функцию.

Тестовый пример для 4 фальшивых операций итератора выглядит следующим образом: предполагается распечатать строку значений узлов графа с помощью фальшивых операций итератора:

gdwg::Graph<std::string,int>> g
   for (g.begin(); !g.end(); g.next())
       std::cout << g.value() << std::end;

Я объявил график следующим образом:

template <typename N, typename E> class Graph {

private:
    struct Node;
    struct Edge;

    struct Node {
        N val_;
        int numEdges_;
        int numIncomingEdges_;
        std::set<std::shared_ptr<Edge>> edges_;
        std::set<std::shared_ptr<Edge>> incomingEdges_;
        Node() {}
        Node(const N x) : val_{x} { numEdges_=0; numIncomingEdges_=0; }
        void printNode(N n);
        ~Node();
        void update();
    };

    struct Edge {
        std::weak_ptr<Node> orig;
        std::weak_ptr<Node> dest;
        E val_;
        Edge(std::shared_ptr<Node> o, std::shared_ptr<Node> d, E x);
        Edge() {};
        void printEdge();
        ~Edge();
    };

    // fake iterator operations
    void begin() const;
    bool end() const;
    void next() const;
    const N& value() const;



public:

    friend class Node_Iterator<N, E>;
    friend class Edge_Iterator<N, E>;


private:
    std::map< N, std::shared_ptr<Node> > nodes_;

    // fake iterator to be used for the four operations begin(), end(), next() and value()
    mutable typename std::map< N, std::shared_ptr<Node> >::iterator fakeIter_;

};

Выполнение 4 операций выглядит следующим образом:

// void begin() const: Sets an internal iterator, i.e., ``pointer'' to the first element of a sequence.
template <typename N, typename E>
void Graph<N,E>::begin() const {
    // gets iterator to the first key/value pair in map sequence
    fakeIter_ = nodes_.begin();
}

// bool end() const: Returns true if the iterator goes past the last element of the sequence and false otherwise.
template <typename N, typename E>
bool Graph<N,E>::end() const {
    // return true if iterator goes past last element, otherwise return false
    return ((fakeIter_ == nodes_.end()) ? true : false);
}

// void next() const: Moves the iterator to the next element of the sequence.
template <typename N, typename E>
void Graph<N,E>::next() const {
    fakeIter_ = std::next(fakeIter_, 1);
}

// const N& value() const: Returns the value of the node pointed to by the iterator.
template <typename N, typename E>
const N& Graph<N,E>::value() const {
    return fakeIter_->second->val_;
}

При попытке скомпилировать вылетает куча ошибок. Мне просто интересно, правильно ли я реализую поддельные операции итератора и есть ли способ улучшить его, если это необходимо?

tests/Graph.tem: In instantiation of ‘void gdwg::Graph<N, E>::begin() const [with N = unsigned int; E = int]’:
tests/test13.cpp:23:15:   required from here
tests/Graph.tem:713:12: error: no match for ‘operator=’ (operand types are ‘std::map<unsigned int, std::shared_ptr<gdwg::Graph<unsigned int, int>::Node>, std::less<unsigned int>, std::allocator<std::pair<const unsigned int, std::shared_ptr<gdwg::Graph<unsigned int, int>::Node> > > >::iterator {aka std::_Rb_tree_iterator<std::pair<const unsigned int, std::shared_ptr<gdwg::Graph<unsigned int, int>::Node> > >}’ and ‘std::map<unsigned int, std::shared_ptr<gdwg::Graph<unsigned int, int>::Node>, std::less<unsigned int>, std::allocator<std::pair<const unsigned int, std::shared_ptr<gdwg::Graph<unsigned int, int>::Node> > > >::const_iterator {aka std::_Rb_tree_const_iterator<std::pair<const unsigned int, std::shared_ptr<gdwg::Graph<unsigned int, int>::Node> > >}’)
  fakeIter_ = nodes_.begin();

In file included from /usr/local/include/c++/6.1.0/map:60:0,
                 from tests/Graph.h:19,
                 from tests/test13.cpp:3:
/usr/local/include/c++/6.1.0/bits/stl_tree.h:174:12: note: candidate: constexpr std::_Rb_tree_iterator<std::pair<const unsigned int, std::shared_ptr<gdwg::Graph<unsigned int, int>::Node> > >& std::_Rb_tree_iterator<std::pair<const unsigned int, std::shared_ptr<gdwg::Graph<unsigned int, int>::Node> > >::operator=(const std::_Rb_tree_iterator<std::pair<const unsigned int, std::shared_ptr<gdwg::Graph<unsigned int, int>::Node> > >&)
     struct _Rb_tree_iterator
            ^~~~~~~~~~~~~~~~~
/usr/local/include/c++/6.1.0/bits/stl_tree.h:174:12: note:   no known conversion for argument 1 from ‘std::map<unsigned int, std::shared_ptr<gdwg::Graph<unsigned int, int>::Node>, std::less<unsigned int>, std::allocator<std::pair<const unsigned int, std::shared_ptr<gdwg::Graph<unsigned int, int>::Node> > > >::const_iterator {aka std::_Rb_tree_const_iterator<std::pair<const unsigned int, std::shared_ptr<gdwg::Graph<unsigned int, int>::Node> > >}’ to ‘const std::_Rb_tree_iterator<std::pair<const unsigned int, std::shared_ptr<gdwg::Graph<unsigned int, int>::Node> > >&’
/usr/local/include/c++/6.1.0/bits/stl_tree.h:174:12: note: candidate: constexpr std::_Rb_tree_iterator<std::pair<const unsigned int, std::shared_ptr<gdwg::Graph<unsigned int, int>::Node> > >& std::_Rb_tree_iterator<std::pair<const unsigned int, std::shared_ptr<gdwg::Graph<unsigned int, int>::Node> > >::operator=(std::_Rb_tree_iterator<std::pair<const unsigned int, std::shared_ptr<gdwg::Graph<unsigned int, int>::Node> > >&&)
/usr/local/include/c++/6.1.0/bits/stl_tree.h:174:12: note:   no known conversion for argument 1 from ‘std::map<unsigned int, std::shared_ptr<gdwg::Graph<unsigned int, int>::Node>, std::less<unsigned int>, std::allocator<std::pair<const unsigned int, std::shared_ptr<gdwg::Graph<unsigned int, int>::Node> > > >::const_iterator {aka std::_Rb_tree_const_iterator<std::pair<const unsigned int, std::shared_ptr<gdwg::Graph<unsigned int, int>::Node> > >}’ to ‘std::_Rb_tree_iterator<std::pair<const unsigned int, std::shared_ptr<gdwg::Graph<unsigned int, int>::Node> > >&&’

person iteong    schedule 19.09.2016    source источник


Ответы (1)


Эта первая ошибка говорит о том, что, поскольку ваша функция begin равна const, nodes_.begin() вернет const_iterator. Это не может быть назначено iterator, типу fakeIter_.

Вам нужно будет удалить const из begin, изменить тип fakeIter_ или изменить свою реализацию (begin должен возвращать итератор, а не пустоту).

person 1201ProgramAlarm    schedule 19.09.2016
comment
Я не могу удалить константу из начала или изменить возвращаемый тип реализации с void на итератор в соответствии со спецификациями. Так что единственное, что я могу сделать, это изменить тип fakeIter_ на основе того, что вы сказали. Как мне это изменить? - person iteong; 19.09.2016