Как определить итератор вложенного контейнера? - PullRequest
1 голос
/ 27 января 2011

Как правильно объявить итератор i в следующем коде?

#include <iostream>
#include <vector>

using namespace std;

template<class Mat> 
void f(const Mat& mat) 
{
    typedef typename Mat::value_type::iterator itr;
    //itr i = (mat.begin())->begin(); //This Line Gives an error
    typeof((mat.begin())->begin()) i = (mat.begin())->begin(); 
}

int main() 
{
    vector<vector<int> > vvi;
    f(vvi);
    return 0; 
}

Ответы [ 4 ]

3 голосов
/ 27 января 2011

Сделайте это STL способом и передайте итераторы, а не контейнеры:

//Beware, brain-compiled code ahead!
template<typename It> 
void f(It begin, It end) 
{
    typedef typename std::iterator_traits<It>::value_type cont;
    typedef typename cont::const_iterator const_iterator; // note the const_ pfx
    const_iterator i = begin->begin();
    // ...
}

int main() 
{
    vector<vector<int> > vvi;
    f(vvi.begin(), vvi.end());
    return 0; 
}
2 голосов
/ 27 января 2011

Ваш контейнер const, но тип вашего итератора - нет.Сделать это const_iterator:

template<class Mat> 
void f(const Mat& mat) 
{
    typedef typename Mat::value_type::const_iterator itr;

    itr i = mat.begin()->begin();
}
1 голос
/ 27 января 2011

Вы проходите как const &, поэтому вам нужен const_iterator :

typedef typename Mat::value_type::const_iterator itr;
itr i = (mat.begin())->begin();
1 голос
/ 27 января 2011

Попробуйте постоянный итератор:

typedef typename Mat::value_type::const_iterator itr;
...