Перебор всех пар элементов в std-контейнерах (C ++) - PullRequest
13 голосов
/ 01 декабря 2009

Каков наилучший способ перебора всех пар элементов в стандартном контейнере, например std::list, std::set, std::vector и т. Д.

В основном, чтобы сделать эквивалент этого, но с итераторами:

for (int i = 0; i < A.size()-1; i++)
    for(int j = i+1; j < A.size(); j++)
        cout << A[i] << A[j] << endl;

Ответы [ 2 ]

13 голосов
/ 01 декабря 2009

Самый простой способ - просто переписать код буквально:

for (auto i = foo.begin(); i != foo.end(); ++i) {
  for (auto j = i; ++j != foo.end(); /**/) {
     std::cout << *i << *j << std::endl;
  }
}

Заменить auto на const_iterator для C ++ 98/03. Или поместите это в его собственную функцию:

template<typename It>
void for_each_pair(It begin, It end) {
  for (It  i = begin; i != end; ++i) {
    for (It j = i; ++j != end; /**/) {
       std::cout << *i << *j << std::endl;
    }
  }
}
1 голос
/ 01 декабря 2009

Просто чтобы пройти, используйте const_iterators. Если вы хотите изменить значения, используйте итератор.

Пример:

typedef std::vector<int> IntVec;

IntVec vec;

// ...

IntVec::const_iterator iter_cur = vec.begin();
IntVec::const_iterator iter_end = vec.end();
while (iter_cur != iter_end) {
    int val = *iter_cur;
    // Do stuff with val here
    iter_cur++;
}
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...